

# Gowin Design Timing Constraints **User Guide**

SUG940-1.8.3E, 12/31/2024

### Copyright © 2024 Guangdong Gowin Semiconductor Corporation. All Rights Reserved.

GOWIN and LittleBee are trademarks of Guangdong Gowin Semiconductor Corporation and are registered in China, the U.S. Patent and Trademark Office, and other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders. No part of this document may be reproduced or transmitted in any form or by any means, electronic, mechanical, photocopying, recording or otherwise, without the prior written consent of GOWINSEMI.

#### Disclaimer

GOWINSEMI assumes no liability and provides no warranty (either expressed or implied) and is not responsible for any damage incurred to your hardware, software, data, or property resulting from usage of the materials or intellectual property except as outlined in the GOWINSEMI Terms and Conditions of Sale. GOWINSEMI may make changes to this document at any time without prior notice. Anyone relying on this documentation should contact GOWINSEMI for the current documentation and errata.

# **Revision History**

| Date                                                                       | Version                                                                           | Description                                                                                       |  |
|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|
| 06/09/2020                                                                 | 1.0E                                                                              | Initial version published.                                                                        |  |
| 00/01/2020                                                                 | 1 1 5                                                                             | Automotive grade added in operating condition;                                                    |  |
| 09/01/2020 1.1E                                                            |                                                                                   | The link between base clock and generated clock added.                                            |  |
| 06/16/2021 1.2E                                                            |                                                                                   | The descriptions of wildcards added.                                                              |  |
| 00/10/2021                                                                 | 1.22                                                                              | Some figures updated.                                                                             |  |
|                                                                            |                                                                                   | Software version updated.                                                                         |  |
| 11/02/2021                                                                 | 1.3E                                                                              | Some figures and corresponding descriptions updated.                                              |  |
|                                                                            |                                                                                   | Appendix A Timing Constraints Syntax Specification updated.                                       |  |
| 05/20/2022                                                                 | 1.3.1E                                                                            | Some language descriptions updated.                                                               |  |
|                                                                            |                                                                                   | -Add option added in Create Clock.                                                                |  |
| 07/28/2022                                                                 | 1.4E                                                                              | The description of temperature and voltage of delay data model updated.                           |  |
|                                                                            |                                                                                   | The descriptions of tUnc and tSu added.                                                           |  |
|                                                                            |                                                                                   | The function of wildcard character cross-hierarchy matching added.                                |  |
| 12/13/2022                                                                 | 1.4.1E                                                                            | The description of Add delay in 4.7.2 I/O Delay Constraints updated.                              |  |
|                                                                            |                                                                                   | The descriptions of set_input_delay and set_output_delay in 4.7.2 I/O                             |  |
| 03/31/2023                                                                 | 1.4.2E                                                                            | Delay Constraints updated.                                                                        |  |
|                                                                            |                                                                                   | The description of 5.1.4 Total Negative Slack Summary updated.                                    |  |
| 04/20/2023                                                                 | 1.4.3E                                                                            | Figure 4-8 New Constraint, Figure 4-9 Open Timing Constraint, and the related descriptions added. |  |
| 05/25/2023                                                                 | 1.5E                                                                              | The descriptions of exception constraints updated.                                                |  |
| 00/20/2020                                                                 | 1.32                                                                              | The descriptions of the virtual clock DEFAULT_CLK updated.                                        |  |
| 08/18/2023                                                                 | 1.5.1E                                                                            | <ul> <li>set_operation_conditions modified to set_operating_conditions.</li> </ul>                |  |
| 00/10/2020                                                                 | 1.5.12                                                                            | The constraint descriptions of reporting max. clock frequency updated.                            |  |
|                                                                            | 1.6E                                                                              | Descriptions of conversion between clock period and frequency removed.                            |  |
| 11/30/2023                                                                 |                                                                                   | Process window screenshot and related description removed.                                        |  |
|                                                                            |                                                                                   | Descriptions of A.2.2 set_output_delay updated.                                                   |  |
| 02/02/2024                                                                 | 1.7E                                                                              | .7E derive_clocks constraint added.                                                               |  |
| 06/28/2024                                                                 | 1.8E                                                                              | Use case for DCS in -add option added in create_clock.                                            |  |
| 08/09/2024                                                                 | Figure 5-1 Static Timing Analysis Report and Figure 5-2 Timing Summaries updated. |                                                                                                   |  |
| 10/25/2024                                                                 | 1.8.2E                                                                            | Descriptions of the default conventions for Clock Name in section 5.1.2 Clock Summary enhanced.   |  |
| 12/31/2024 1.8.3E • Figure 4-5 Timing Constraint Editor Interface updated. |                                                                                   | Figure 4-5 Timing Constraint Editor Interface updated.                                            |  |

| Date | Version | Description                                                             |  |
|------|---------|-------------------------------------------------------------------------|--|
|      |         | Examples in Appendix A Timing Constraints Syntax Specification updated. |  |

# **Contents**

| C | Contents                                   | i  |
|---|--------------------------------------------|----|
| L | _ist of Figures                            | iv |
| L | _ist of Tables                             | vi |
| 1 | About This Guide                           | 1  |
|   | 1.1 Purpose                                |    |
|   | 1.2 Related Documents                      |    |
|   | 1.3 Terminology and Abbreviations          | 1  |
|   | 1.4 Support and Feedback                   | 2  |
| 2 | 2 Introduction                             | 3  |
| 3 | STA Overview                               | 4  |
|   | 3.1 Overview                               |    |
|   | 3.2 Basic Model                            |    |
|   | 3.3 Terms                                  | 5  |
|   | 3.4 Path                                   | 5  |
|   | 3.5 Common Timing Checks                   | 6  |
|   | 3.5.1 Setup Time and Hold Time Check       | 6  |
|   | 3.5.2 Recovery Time and Removal Time Check | 6  |
|   | 3.5.3 MPW Check                            | 6  |
| 4 | 1 Timing Constraints Editor                | 7  |
|   | 4.1 Overview                               | 7  |
|   | 4.2 Start Timing Constraints Editor        | 7  |
|   | 4.3 Create/Open/Add Constraints File       | 7  |
|   | 4.3.1 Create Constraints File              | 7  |
|   | 4.3.2 Open Constraints File                | 9  |
|   | 4.3.3 Add Constraints File                 | 10 |
|   | 4.4 Timing Constraints Editor Interface    | 10 |
|   | 4.5 Open Timing Constraints Window         | 12 |
|   | 4.6 Edit SDC File                          | 13 |
|   | 4.7 Create Timing Constraints              | 14 |

|    | 4.7.1 Clock Constraints                           | . 14 |
|----|---------------------------------------------------|------|
|    | 4.7.2 I/O Delay Constraints                       | . 23 |
|    | 4.7.3 Timing Exceptions Constraints               | . 25 |
|    | 4.7.4 Operating Conditions Constraints            | . 29 |
|    | 4.7.5 Reports                                     | . 30 |
|    | 4.7.6 Other Constraints                           | . 37 |
|    | 4.7.7 Save                                        | . 39 |
|    | 4.8 Priority of Timing Constraints                | . 39 |
| 5  | Timing Report                                     | 40   |
|    | 5.1 Timing Summaries                              | . 41 |
|    | 5.1.1 STA Tool Run Summary                        | . 41 |
|    | 5.1.2 Clock Summary                               | . 42 |
|    | 5.1.3 Max Frequency Summary                       | . 43 |
|    | 5.1.4 Total Negative Slack Summary                | . 43 |
|    | 5.2 Timing Details                                | . 43 |
|    | 5.2.1 Path Slacks Table                           | . 43 |
|    | 5.2.2 Minimum Pulse Width Table                   | . 45 |
|    | 5.2.3 Timing Report By Analysis Type              | . 45 |
|    | 5.2.4 Minimum Pulse Width Report                  | . 50 |
|    | 5.2.5 High Fanout Nets Report                     | . 51 |
|    | 5.2.6 Route Congestions Report                    | . 51 |
|    | 5.2.7 Timing Exceptions Report                    | . 52 |
|    | 5.2.8 Timing Constraints Report                   | . 55 |
| Αŗ | ppendix A Timing Constraints Syntax Specification | 56   |
|    | A.1 Clock Constraints                             | . 56 |
|    | A.1.1 create_clock                                | . 56 |
|    | A.1.2 create_generated_clock                      | . 58 |
|    | A.1.3 set_clock_latency                           | . 60 |
|    | A.1.4 set_clock_uncertainty                       | . 61 |
|    | A.1.5 set_clock_groups                            | . 62 |
|    | A.2 I/O Delay Constraints                         | . 63 |
|    | A.2.1 set_input_delay                             | . 63 |
|    | A.2.2 set_output_delay                            | . 64 |
|    | A.3 Timing Path Constraints                       | . 66 |
|    | A.3.1 set_max_delay/ set_min_delay                | . 66 |
|    | A.3.2 set_false_path                              | . 67 |
|    | A 3.3 set_multicycle_path                         | 69   |

| A.4 Operating Conditions Constraints | 70 |
|--------------------------------------|----|
| A.5 Timing Report Constraints        | 71 |
| A.5.1 report_timing                  | 71 |
| A.5.2 report_high_fanout_nets        | 73 |
| A.5.3 report_route_congestion        | 74 |
| A.5.4 report_min_pulse_width         | 74 |
| A.5.5 report_max_frequency           | 75 |
| A.5.6 report_exceptions              | 75 |
| A.6 Other Constraints                | 77 |
| A.6.1 derive clocks                  | 77 |

# **List of Figures**

| Figure 3-1 Basic Model Diagram                            | . 4  |
|-----------------------------------------------------------|------|
| Figure 3-2 Four Types of Timing Paths                     | . 5  |
| Figure 4-1 New Dialog Box                                 | . 8  |
| Figure 4-2 New Timing Constraints File                    | . 8  |
| Figure 4-3 Open Timing Constraints File                   | . 9  |
| Figure 4-4 Add Constraints File                           | . 10 |
| Figure 4-5 Timing Constraint Editor Interface             | . 10 |
| Figure 4-6 Netlist Tree View                              | . 11 |
| Figure 4-7 Constraints Editing Window                     | . 11 |
| Figure 4-8 New Constraint                                 | . 12 |
| Figure 4-9 Open Timing Constraint                         | . 12 |
| Figure 4-10 Open Timing Constraints Window via Menu Bar   | . 13 |
| Figure 4-11 Right-click to Open Timing Constraints Window | . 13 |
| Figure 4-12 Edit SDC File                                 | . 14 |
| Figure 4-13 Create Clock                                  | . 15 |
| Figure 4-14 Select Objects                                | . 16 |
| Figure 4-15 Add Clock                                     | . 16 |
| Figure 4-16 Clock List                                    | . 17 |
| Figure 4-17 Right-click Menu for the Clock                | . 17 |
| Figure 4-18 Create Generated Clock Constraints            | . 18 |
| Figure 4-19 Select Create Generated Clock                 | . 19 |
| Figure 4-20 Set Clock Latency                             | . 20 |
| Figure 4-21 Set Clock Uncertainty                         | . 21 |
| Figure 4-22 Set Clock Groups                              | . 23 |
| Figure 4-23 Create I/O Delay Constraints                  | 25   |
| Figure 4-24 Create False Path Constraints                 | . 26 |
| Figure 4-25 Create Max/Min Delay Constraints              | . 27 |
| Figure 4-26 Create Multicycle Path Constraints            | . 28 |
| Figure 4-27 Create Operating Conditions Constraints       | . 29 |
| Figure 4-28 Create Report Timing                          | . 30 |

| Figure 4-29 Report Timing Dialog Box           | 31 |
|------------------------------------------------|----|
| Figure 4-30 Create Report High Fanout Nets     | 32 |
| Figure 4-31 Report High Fanout Nets Dialog Box | 32 |
| Figure 4-32 Report Route Congestion Interface  | 33 |
| Figure 4-33 Report Route Congestion Dialog Box | 33 |
| Figure 4-34 Create Report Min Pulse Width      | 34 |
| Figure 4-35 Report Min Pulse Width Dialog Box  | 35 |
| Figure 4-36 Create Report Max Frequency        | 35 |
| Figure 4-37 Report Max Frequency Dialog Box    | 36 |
| Figure 4-38 Create Report Exception            | 36 |
| Figure 4-39 Report Exception Dialog Box        | 37 |
| Figure 4-40 Create Derive Clocks               | 37 |
| Figure 4-41 Select Create Derive Clocks        | 38 |
| Figure 4-42 Derive Clocks List                 | 38 |
| Figure 5-1 Static Timing Analysis Report       | 40 |
| Figure 5-2 Timing Summaries                    | 41 |
| Figure 5-3 Path & Endpoints                    | 42 |
| Figure 5-4 Path Slacks Table                   | 44 |
| Figure 5-5 Minimum Pulse Width Table           | 45 |
| Figure 5-6 Path Summary                        | 46 |
| Figure 5-7 Data Arrival Path                   | 47 |
| Figure 5-8 Data Required Path                  | 47 |
| Figure 5-9 Path Statistics                     | 48 |
| Figure 5-10 Hold Analysis Report               | 48 |
| Figure 5-11 Recovery Analysis Report           | 49 |
| Figure 5-12 Removal Analysis Report            | 50 |
| Figure 5-13 Minimum Pulse Width                | 51 |
| Figure 5-14 High Fanout Nets Report            | 51 |
| Figure 5-15 Route Congestions Report           | 52 |
| Figure 5-16 Test Case                          | 52 |
| Figure 5-17 Timing Exceptions Constraints      | 52 |
| Figure 5-18 Timing Exceptions Report           | 53 |
| Figure 5-19 report_exception Statement         | 54 |
| Figure 5-20 report_exception Report            | 54 |
| Figure 5-21 Timing Constraints Report          | 55 |

# **List of Tables**

| Table 1-1 | Terminology | and Abbreviations |
|-----------|-------------|-------------------|
|-----------|-------------|-------------------|

SUG940-1.8.3E vi

1 About This Guide 1.1 Purpose

# 1 About This Guide

## 1.1 Purpose

This manual describes the timing constraints, including timing constraints editor usage, syntax definition and static timing analysis report (hereinafter referred to as timing report). It aims to help you realize timing constraints and how to read Static Timing Analysis (STA) reports.

## 1.2 Related Documents

The latest user guides are available on GOWINSEMI Website: <a href="https://www.gowinsemi.com">www.gowinsemi.com</a>. You can find the related document <a href="https://succeedings.org/succeedings-to-2016/8/">SUG918, Gowin Software Quick Start Guide.

# 1.3 Terminology and Abbreviations

Table 1-1 shows the abbreviations and terminology that are used in this manual.

Table 1-1 Terminology and Abbreviations

| Terminology and Abbreviations | Meaning                    |
|-------------------------------|----------------------------|
| GUI                           | Graphical User Interface   |
| MPW                           | Minimum Pulse Width        |
| OSC                           | Oscillator                 |
| PnR                           | Placement and Route        |
| REG                           | Register                   |
| SDC                           | Synopsys Design Constraint |
| STA                           | Static Timing Analysis     |

SUG940-1.8.3E 1(77)

# 1.4 Support and Feedback

Gowin Semiconductor provides customers with comprehensive technical support. If you have any questions, comments, or suggestions, please feel free to contact us directly using the information provided below.

Website: <a href="www.gowinsemi.com">www.gowinsemi.com</a>
E-mail: <a href="mailto:support@gowinsemi.com">support@gowinsemi.com</a>

SUG940-1.8.3E 2(77)

# 2 Introduction

This manual includes three parts: STA, Timing Constraint Editor and Timing Report.

STA introduces the basic concepts, which is intended to help you understand the basic principles of timing analysis, learn timing constraints editor usage and read timing reports.

The timing constraints editor is a GUI tool that can create and modify SDC file, and a timing report is generated according to the timing constraints after Place and Route.

#### **Function**

- Supports clock constraints, such as base clock, generated clock constraints, source delay and uncertainty constraints and group constraints
- Supports the input and output delay constraints of data port
- Supports exception constraints, such as multi-cycle, maximum and minimum path delay constraints, and false path constraints
- Supports the report constraints, such as the max. frequency of the module and route congestion of grid
- Provides efficient netlist lookup and expression matching
- The GUI is flattened, simple and clear

#### **Feature**

- Strictly follows the W3C XHTML 1.0 specification
- Can be opened with an external browser
- Can be printed in TXT format
- Supports navigation bar and quick positioning
- Reports all constraints generated by timing constraints editor
- Easy to read with clear hierarchy

SUG940-1.8.3E 3(77)

3 STA Overview 3.1 Overview

# 3 STA Overview

## 3.1 Overview

STA comprehensively analyzes the timing model in netlist, calculates the timing delay and determines whether it meets the requirements. The designer needs to provide constraint incentives, and Gowin Software completes the analysis automatically. Compared with the traditional analysis method, it features short verification time and high coverage.

The basic models, terms and concepts involved in STA are described below.

## 3.2 Basic Model

STA is a model analysis that starts from and ends with the timing component. The basic model diagram is shown in Figure 3-1. The REG1 triggers data from D to Q at the active edge. The data arrives at REG2 via logic circuit. Then the REG2 captures the data transmitting from REG1 at the active edge. STA is employed to verify whether REG2 can capture the data from the REG1 correctly.

Figure 3-1 Basic Model Diagram



The active edge of REG1 is called launch edge, and the active edge of REG2 is called latch edge.

SUG940-1.8.3E 4(77)

3 STA Overview 3.3 Terms

### 3.3 Terms

The basic timing units involved in the timing model are as follows:

Cells: Basic elements such as LUT, DFF, MUX, etc.

Pins: I/O port of cells

Ports: I/O ports of top-level module

Nets: net

### 3.4 Path

STA usually analyzes four types of paths and classifies them according to different starts and ends, as shown in Figure 3-2.

I2R: From input to timing cell

• R2R: From timing cell to timing cell

R2O: From timing cell to output

I2O: From input to output.

Figure 3-2 Four Types of Timing Paths



Gowin Software calculates the data arrival time and data required time of each path.

The data arrival time refers to the time from the start to the end of the data path. The data required time refers to the time from the clock start to the end in the timing path. When calculating data arrival time, clock path has a clock skew which refers to the time difference of the clock arriving at the clock port of different timing components.

SUG940-1.8.3E 5(77)

# 3.5 Common Timing Checks

STA usually check the following three types of timing and provides suggestions on PnR to better meet your requirements for timing.

## 3.5.1 Setup Time and Hold Time Check

- Setup time: The shortest time for data stability before the active edge. If the time is not met, the clock cannot capture data.
- Hold time: The shortest time for data stability after clock effective edge, if the time is not met, the clock cannot capture data.

## 3.5.2 Recovery Time and Removal Time Check

- Recovery time: Before active edge, the shortest stability time for asynchronous clear/set/reset signals. If the time is not met, the flip flop may not operate.
- Removal time: After active edge, the shortest stability time for asynchronous clear/set/reset signals. If the time is not met, the flip flop may not operate.

#### 3.5.3 MPW Check

MPW: Min. width of high and low level recognized by flip flop, such as DFF. The clock will not be recognized if the width is lower than MPW.

SUG940-1.8.3E 6(77)

# 4 Timing Constraints Editor

### 4.1 Overview

Gowin Timing Constraints Editor supports timing commands, including clock, input/output, path constraints, and clock report. You can add timing constraints via GUI. For a simple example, see <u>SUG918</u>, <u>Gowin Software</u> Quick Start Guide.

## 4.2 Start Timing Constraints Editor

You can use the Timing Constraints Editor alone or start it after synthesis.

Click "Tools > Timing Constraints Editor" to start. After running Synthesize in Process window, double-click "Process > Timing Constraints Editor" to start the timing constraints editor. The netlist file and the timing constraints file in the project are automatically loaded into the timing constraint editor, or created automatically if there is no timing constraint file in the project.

# 4.3 Create/Open/Add Constraints File

#### 4.3.1 Create Constraints File

The steps of creating constraint files are as follows.

- 1. Click "File > New" and "New" dialog box pops up.
- 2. Select "Timing Constraints File", as shown in Figure 4-1.

#### Note!

You can also create constraints file in the following ways.

- Click the "New" icon in the toolbar.
- Use shortcut "Ctrl+N".

SUG940-1.8.3E 7(77)

Figure 4-1 New Dialog Box



3. Click "OK" and "New Timing Constraints File" pops up, as shown in Figure 4-2.

Figure 4-2 New Timing Constraints File



- 4. Type the file name and select a path, then click "OK", and the created constraints file is automatically loaded into the project.
  - Name: The new file name with .sdc extension; and the name is recommended to use identifiers with engineering-related meaning,

SUG940-1.8.3E 8(77)

beginning with letters or underscores.

- Create in: Select the path by clicking "Browse" and it is stored in src folder in project by default.
- Add to current project: Add the constraints file to the project automatically.

## 4.3.2 Open Constraints File

The steps are as follows.

- 1. On IDE interface, click "File > Open".
- 2. "Open File" dialog box pops up, as shown in Figure 4-3.

#### Note!

You can also open timing constraints file in the following ways:

- Click "Open" icon in the toolbar;
- Use shortcut "Ctrl + O".

Figure 4-3 Open Timing Constraints File



3. Select and open the file with.sdc extension.

#### Note!

The file open operation does not automatically load the file into the project.

SUG940-1.8.3E 9(77)

#### 4.3.3 Add Constraints File

The steps are as follows.

- 1. Right-click and select "Add Files" in Design window.
- 2. "Select Files" dialog box pops up, and select the file with .sdc extension, as shown in Figure 4-4.
- 3. Click "Open" to add one or more selected files to the project.

#### Note!

Only one file is valid when multiple files added.

Figure 4-4 Add Constraints File



## 4.4 Timing Constraints Editor Interface

The editor interface is shown in Figure 4-5.

Figure 4-5 Timing Constraint Editor Interface



SUG940-1.8.3E 10(77)

The Netlist Tree view is as shown in Figure 4-6.

Figure 4-6 Netlist Tree View



The Netlist Tree includes Top Module, I/O Ports, Nets, and Primitives.

- " : Flatten display
- "": Hierarchy display

The constraints editing area is as shown in Figure 4-7. The left is the timing constraints type and the right is the editing area. Click a constraints type, and the constraints editing list will be displayed in editing area.

**Figure 4-7 Constraints Editing Window** 



The toolbar includes New " , Open " , Save " , and

SUG940-1.8.3E 11(77)

Reload "O". In the "New Constraint" dialog box, you can configure "Input Netlist File" and "Device", as shown in Figure 4-8.

**Figure 4-8 New Constraint** 



Click " " to open "Open Timing Constraint" dialog box, you can configure "Input Netlist File", "Constraint File", and "Device", as shown in Figure 4-9.

**Figure 4-9 Open Timing Constraint** 



# 4.5 Open Timing Constraints Window

There are two ways to open.

1. Click "Constraints" in menu. Select timing constraints command to open the window, as shown in Figure 4-10.

SUG940-1.8.3E 12(77)

Figure 4-10 Open Timing Constraints Window via Menu Bar



Right click to select different timing constraints commands, as shown in Figure 4-11.

Figure 4-11 Right-click to Open Timing Constraints Window



## 4.6 Edit SDC File

Gowin Software supports to read SDC file and you can manually modify the SDC file in the timing constraints editor, as shown in Figure 4-12.

The parsing of SDC files supports wildcard; currently two wildcard characters "\*" and "?" are supported. "\*" matches zero or multiple characters, while "?" matches a single character.

SDC files support single line and multi-line comments. Single line comments use "//" or "#", and multi-line comments use "/\* \*/".

SUG940-1.8.3E 13(77)

#### Figure 4-12 Edit SDC File

```
//Copyright (C)2014-2020 GOWIN Semiconductor Corporation.
//All rights reserved.
//File Title: Timing Constraints file
//GOWIN Version: 1.9.6 Beta
//Created Time: 2020-05-28 11:23:17
create_clock -name main -period 20 -waveform {0 10} [get_ports {clk}]

// Start Page Design Summary Bebit_counter.sdc
```

# 4.7 Create Timing Constraints

This section introduces how to create timing constraints using editor. The created timing constraints will be written to the SDC file in the project. You can see Appendix A for details.

#### 4.7.1 Clock Constraints

#### **Create Clock**

Create a base clock.

You can configure parameters, such as name, period, frequency, rising edge, falling edge, etc. Gowin Software can create multiple clocks which form multiple clock domains, and support clock domain crossing analysis.

You can add clock constraints in the following two ways.

- 1. Add Clock constraint via Constraints
  - a) Select "Constraints > Create Clock... ", and the "Create Clock" dialog box pops up, as shown in Figure 4-13.

SUG940-1.8.3E 14(77)

? Create Clock X Clock name: Waveform Period: 10 ns Frequency: 100 MHz Rising: ns Falling: ns n 10 ... 🔲 Add Objects: ΟK Cancel

Figure 4-13 Create Clock

- b) Configure "Clock Name", "Waveform", and "Objects".
  - Clock Name: Supports identifiers beginning with letters or underscores.
  - Period: Floating point greater than 0, accurate to three decimal places, unit in ns, and 10 by default.
  - Frequency: Floating point greater than 0, accurate to three decimal places, unit in MHz, and 100 by default.
  - Rising: Floating point greater than 0, accurate to three decimal places, unit in ns.
  - Falling: Floating point greater than 0, accurate to three decimal places, unit in ns.
  - Objects: Specifies the target; click " to select the object.
  - Add: Checks it when adding multiple clocks to the same source.
- c) Click " and " Select Objects" pops up, as shown in Figure 4-14.

SUG940-1.8.3E 15(77)

Figure 4-14 Select Objects

- d) As shown in Figure 4-14, "Collection" specifies the object type. "Filter" is a filter. After clicking "Search", the objects are displayed on the left, and the selected will be displayed on the right. ">" adds the selected from the left list to the right list. "> " adds all the selected from the left list to the right list. "<" removes the selected in the right list.</p>
- e) Click "OK" to add Objects.
- 2. Add clock constraints via Netlist Tree.
  - a) Select I/O Port or Net in Netlist Tree.
  - b) Right-click and select "Add Clock" to add a clock, as shown in Figure 4-15.

Figure 4-15 Add Clock



SUG940-1.8.3E 16(77)

After finishing, the constraints will be added in clock list, as shown in Figure 4-16.

Figure 4-16 Clock List



You can perform the following operations.

- Double-click the constraints to edit.
- Right-click and select "Remove" to remove the clock.
- Right-click to set Clock Latency, Clock Uncertainty, or I/O Delay, as shown in Figure 4-17.

Figure 4-17 Right-click Menu for the Clock



#### Note!

- When a constraint is inconsistent with the PLL configuration, you should take the one created by Create Clock as the standard. A prompt will pop up in PnR.
- Create Clock does not support virtual clock.

#### **Create Generated Clock**

Create a generated clock based on the base clock.

This constraint allows for operations such as frequency division, frequency multiplication, phase shifting, and duty cycle adjustment based on the base clock, thereby creating the derived clock.

The generated clock must be based on the base clock and you can create at any node in the user design. They are usually applied to the output ports of PLL, CLKDIV and other hard cores. If you use PLL in the design, after the base clock is created, the generated clock with Objects as PLL. CLKOUT and Source as the base clock can be created. The generated clock is automatically linked to the base clock, and the

SUG940-1.8.3E 17(77)

generated clock is automatically corrected to adapt to the base clock when the attributes of the base clock change.

You can create the generated clock in the following two ways:

- 1. Create via constraints
  - a) Select "Create Generated Clock" and "Create Generated Clock" pops up, as shown in Figure 4-18.
  - Clock Name: Supports identifiers beginning with letters or underscores.
  - Source: The source of generated clock; click " to select one.
  - Master Clock: The clock acting on Source; click " " to select one.

Figure 4-18 Create Generated Clock Constraints



- b) You can automatically add the clock associated with Source to "Master Clock" by clicking " on the right side of "Source"; when Master Clock has multiple clocks, only one of them is supported.
- c) In "Relationship to source" pane, you can configure frequency division/multiplication, offset, duty cycle and phase in "Based on frequency"; and you can also adjust edge in "Based on waveform".

SUG940-1.8.3E 18(77)

- Divide by: Division, positive integer.
- Phase: Floating point accurate to three decimal places, with negative values indicating left shift and positive values indicating right shift.
- Multiply by: Multiplication, positive integer.
- Offset: Floating point accurate to three decimal places, with negative values indicating left shift and positive values indicating right shift.
- Duty cycle: Floating point accurate to three decimal places; value not greater than 100.
- Edge list: Positive integer increased sequentially.
- Edge shift list: Floating point accurate to three decimal places.
- d) You can invert clocks by clicking "Invert waveform" and add clocks by clicking "Add".
- e) In "Objects", click " and "Select Objects" pops up to select the object.

#### Note!

- If there is no clock in Source, Master Clock has no option, and you need to select Source again.
- When a constraint is inconsistent with the PLL configuration, you should take the one created by Create Generated Clock as the standard. A prompt will pop up in PnR.
- 2. Create generated clock from clocks list. Right-click and select "Create Generated Clock" to create generated clock, as shown in Figure 4-19.

Figure 4-19 Select Create Generated Clock



The new constraints will be added.

You can perform the following operations.

- Double-click the constraints to edit.
- Select the clock and right-click to select "Remove" to remove the clock.

#### **Set Clock Latency**

It is used to set the latency before clock signal reaching device port. You can configure the max./min. latency respectively for rising /falling edges.

Clock latency includes two types: network latency and source latency.

SUG940-1.8.3E 19(77)

- Network latency is internal clock path delay.
- Source latency is external clock path delay.

Gowin Software will calculate clock network latency automatically, so you only need to set source latency.

The latency of the clock signal from the clock source (external crystal oscillator) to the FPGA clock port is called the source latency, which is not automatically known by Gowin Software. The default value is 0ns. If you know the source latency 2ns, the Delay Value can be configured as of 2ns, and Gowin Software will add 2ns value automatically in timing analysis. The results can be found in Tcl of the Setup and Hold reports.

You can create clock latency constraints in the following two ways.

- Select "Set Clock Latency" in "Constraints" menu, and Set Clock Latency dialog box pops up, as shown in Figure 4-20.
  - Early and Late: Indicates the earliest and latest latency values for the set clock.
  - Rise and Fall are valid for rising edge and falling edge; Both indicates Rise and Fall both are valid.
  - Objects: Specifies the clock input port or clock; select one by clicking "-".
  - Clocks: Specifies a clock; select one by clicking "
     ".

Figure 4-20 Set Clock Latency



 Create Clock Latency constraints in clocks list. Select a clock in clock list; right-click and select Set Clock Latency; this clock will be automatically selected in Objects.

SUG940-1.8.3E 20(77)

#### **Set Clock Uncertainty**

It is used to set clock uncertainty or offset to analyze clock transmission.

It can set uncertainty for setup and hold, or clock rising edge and falling edge. You can inform Gowin Software of clock jitter and pessimism via the constraints to affect timing calculation.

An ideal clock signal does not generate uncertainty. However, the clock uncertainty usually exists, and Gowin Software will calculate the uncertainties by default. You can also provide a more reasonable uncertainties according to the actual hardware environment to Gowin Software for analysis. Assuming that the device works in a strong magnetic environment and the uncertain value is 0.2ns, then Uncertainty can be set as 0.2ns. The results can be found in tUnc of the Setup and Hold reports.

The steps to create clock uncertainty are as follows.

- 1. In "Constraints", select "Set Clock Uncertainty" and "Set Clock Uncertainty" pops up, as shown in Figure 4-21.
  - From clock: Specifies the start clock, selected by clicking " \ " on the right.
  - To clock: Specifies the end clock, selected by clicking " " on the right.
  - Uncertainty: Floating point accurate to three decimal places, unit in ns.
  - Analysis type: Indicates the type of analysis.

Figure 4-21 Set Clock Uncertainty



2. Use the dropdown menus on the left to select the type of "From" (From clock, Rise from, Fall from) and the type of "To" (To clock, Rise to, Fall to). Then, use the dropdown menus on the right to select the target clock from all currently created clocks.

SUG940-1.8.3E 21(77)

3. Click "OK" to add uncertainty.

#### **Set Clock Group**

It used to specify the relationship between different clocks.

Gowin Software provides the relationship between the group members by default, and there is no correlation between groups. Gowin Software defaults to the fact that all clocks in the design belong to a group and are related.

The constraint is usually used for mutual exclusive or asynchronous clocks. For example, there are CLK1 and CLK2 with different frequencies in the design, and only one clock is valid at the same time via a multiple-selection.

It is recommended that you specify the relationship between clocks and create clock group constraints for asynchronous or mutually exclusive clocks.

You can create clock group in the following ways.

- 1. In "Constraints", select "Set Clock Groups" and "Set Clock Groups" dialog box pops up, as shown in Figure 4-22.
  - Group: Specifies the clock, at least one clock, selected by clicking
     " on the right.
  - Add: Add a group.
  - Set Mutex Clocks: Sets multiple groups at one time.
  - Exclusive: Indicates clocks are exclusive. For example, Clock0 and Clock1 pass through a MUX2 and outputs Clock3 acting on a timing model, and Clock3 can only take Clock0 and Clock1 at the same time; then you can check this option.
  - Asynchronous: Indicates that clock asynchronization is not related, and the clock has different clock sources. For example, a timing model is transmitted and sampled by Clock0 and Clock1, which can be from different external ports.

SUG940-1.8.3E 22(77)

Figure 4-22 Set Clock Groups



- 2. Click " to select Clock for group; and click "★" to remove the clock.
- 3. Click "OK" to save.

#### Note!

The options "Exclusive" and "Asynchronous" achieve the same result.

## 4.7.2 I/O Delay Constraints

### set\_input\_delay

Set the delay value of data input, and you analyze the relationship between data arrival and clock arrival; users need to set a reasonable input delay value, and Gowin Software will analyze the slack based on the given delay value.

#### Note!

The input delay type in the timing report is "tln".

#### set\_output\_delay

Set the delay value of data output, and you analyze the relationship between data output and clock output; users need to set a reasonable output delay value, and Gowin Software will analyze the slack based on the given delay value.

#### Note!

The output delay type in the timing report is "tOut".

You can create I/O delay constraints as follows.

- 1. In "Constraints" menu, select "Set I/O Delay" and "Set I/O Delay" dialog box pops up, as shown in Figure 4-23.
  - Clock name: Indicates the clock associated with I/O; the clock must

SUG940-1.8.3E 23(77)

- exist, and click " " to select it.
- Options: Configure delay type, maximum and minimum delay, clock edge, etc.
- Input delay/Output delay: Specifies the input/output delay, and they are exclusive.
- Minimum/Maximum: Specifies the minimum or maximum delay value of I/O; both indicate that both delay values are the same.
- Rise/Fall: Indicates that rising or falling edge is valid; both indicate that they are both valid at the same time.
- Delay value: Used to set the delay value for I/O, a positive or negative floating point accurate to three decimal places. When it is a negative number, it indicates an advance arrival, and when it is a positive number, it indicates a delayed arrival, measured in ns.
- Objects: Specifies the input and output ports, and click "
   on to select one.
- Add delay: Used to add a delay value to the same port; when there
  are multiple delay values on the same port, Gowin Software will
  select the largest one for Setup analysis and the smallest one for
  Hold analysis; if this option is not specified, the same constraint on
  the same port will be overwritten.
- Use falling clock edge: If checked, the falling edge of the associated clock is related; the default is rising edge related.
- Source Latency include: If checked, it indicates that the delay value set includes the delay value of the clock; if not checked, Gowin Software will count in the delay value of the clock.

SUG940-1.8.3E 24(77)



Figure 4-23 Create I/O Delay Constraints

2. Click "OK" to save the constraints.

## 4.7.3 Timing Exceptions Constraints

Timing exceptions allow users to modify the default static timing analysis rules for a specific path. The timing exception constraint commands includes four types: set\_false\_path, set\_multicycle\_path, set\_max\_delay, and set\_min\_delay.

#### Set False Path

It is used to set a false path.

Gowin Software will analyze all timing paths. Set False Path specifies the paths in the design that do not need to be analyzed. It is recommended that users use this statement to specify a path that does not need to be analyzed.

There are usually two types of timing paths that do not require analysis.

- The timing circuit unrelated to operating, such as the test circuit.
- The path across the asynchronous clock domain. Assuming that there are register A and register B, A outputs data to B, and A and B are respectively driven by asynchronous clocks CLK1 and CLK2. Then From can be configured as CLK1 and To as CLK2, and the path from CLK1 launch to CLK2 latch will not be analyzed.

You can create False Path constraints as follows:

SUG940-1.8.3E 25(77)

- 1. Select "Constraints > Set False Path", then "Set False Path" pops up, as shown in Figure 4-24.
  - Analysis type: Checks Setup or Hold; Both indicate both are checked.
  - From: Indicates the start of the path.
  - To: Indicates the end of the path.
  - Through: Indicates the pins or nets through the path.

#### Note!

From, To and Through can be used individually or together with each other.

**Figure 4-24 Create False Path Constraints** 



2. Click " to select objects, as shown in Figure 4-14. Click "OK" to save.

#### Set Max/Min Delay

It is used to specify the maximum and minimum delay values on a path.

It is usually used in pin-to-pin delay analysis. If the input port A is output to port B after combinational logic, Gowin software does not analyze and report the path from port A to port B by default. You can use this constraint to specify a delay value from port A to port B. Gowin Software automatically calculates, analyzes and reports the path specified by you. The maximum delay is reported in Setup, and the minimum delay is reported in Hold.

You can create Max/Min Delay constraints as follows:

- Select "Constraints > Set Max/Min Delay", then "Set Max/Min Delay" pops up, as shown in Figure 4-25.
  - From: Indicates the start of the path; click " to select one.
  - To: Indicates the end of the path; click " to select one.

SUG940-1.8.3E 26(77)

- Through: Indicates the pins or nets through the path; click " to select one.
- Delay value: Sets delay value; Floating point accurate to three decimal places.
- Delay value is the user-specified delay value, a floating point accurate to three decimal places, measured in ns.

#### Note!

From, To and Through can be used individually or together with each other.

Figure 4-25 Create Max/Min Delay Constraints



2. Select type (Max or Min) in Delay Type and select Objects in From/To. Click "OK" to save.

#### Set MultiCycle Path

It is used to set a multicycle path.

By default, Gowin Software performs single-cycle clock analysis, that is, the check of setup time is on the active clock edge of the next clock cycle at the edge of the source clock, but this method does not apply to certain timing paths. Logic design circuit is the most typical example. More than one clock cycle data shall be needed to stabilize if a logic circuit calculates more complex or longer path.

If the data on the timing Path\_A in the design needs two cycles to stabilize, and Gowin Software defaults to the one cycle analysis. You need to set Value to 2, and Gowin Software can analyze according to the value. The results can be found in the Setup and Hold reports.

#### Note!

 Setting the multicycle path command will affect the setup time and the hold time. If the -setup or -hold option is not specified, Gowin Software defaults to -setup. If -setup

SUG940-1.8.3E 27(77)

value is set, hold value will not be affected.

 Gowin Software provides the function to automatically repair Hold by default. If you specify a hold value, Gowin Software will prioritize user setting.

You can create multicycle path constraints as follows:

- 1. Select "Constraints > Set Multicycle Path", then "Set Multicycle Path" pops up, as shown in Figure 4-26.
  - Reference clock: Indicates whether the reference clock is launch or latch clock.
  - Analysis type: Specifies constraints on Setup or Hold check.

  - Through: Indicates the pins or nets through the path; click "..." to select one.
  - To: Indicates the end of the path; click " to select one.
  - Value: Specifies the number of multi-cycle periods, positive or negative integer; negative means advance, and positive means delay.

#### Note!

From, To and Through can be used individually or together with each other.

Figure 4-26 Create Multicycle Path Constraints

| 🕸 Set Multicycle Path         | ? ×                                                     |
|-------------------------------|---------------------------------------------------------|
| From: Through:                |                                                         |
| To:                           |                                                         |
| Analysis type  © Setup  OHold | Reference clock  Start(launch clock)   End(latch clock) |
| Value:                        | OK Cancel                                               |

2. Click "OK" to save the constraints.

SUG940-1.8.3E 28(77)

# 4.7.4 Operating Conditions Constraints

The delay model used in timing constraints analysis can specify the speed level, model type and so on. Gowin Software uses Slow Model for Setup analysis and Fast Model for Hold analysis by default.

You can also customize the timing model. For example, in the case of hot and unstable power supply, the slow delay model can be specified. You can check the delay model in STA Tool Run Summary.

Select "Constraints > Set Operating Conditions", then "Set Operating Conditions" dialog box pops up, as shown in Figure 4-27.

- Grade: Commercial, industrial and automotive.
- Model: Slow and fast.
- Hold and Setup: Indicates hold time and setup time valid.
- Max function is the same as Setup, and Min function is the same as Hold.
- Max-Min is equivalent to selecting both Max and Min.

**Figure 4-27 Create Operating Conditions Constraints** 



#### Note!

- When the set grade and speed do not match the chip part number, the actual constraint shall prevail.
- If the grade and speed of the actual constraints do not support the current project,
   Gowin Software will report a warning message.
- If Grade-Speed is set to Setup only, Hold is analyzed according to the Grade-Speed set by Setup.
- If Grade-Speed is set to Hold only, Setup is analyzed according to the Grade-Speed set by Hold.
- The engineering sample (ES) uses the slowest speed to analyze the timing sequence by default, and you can set the speed of engineering sample as required.

SUG940-1.8.3E 29(77)

# 4.7.5 Reports

#### **Report Timing**

It is used to report timing paths and slacks.

According to the set parameters, Gowin Software can provide reports with more details.

For example, Gowin Software reports 25 Setup analysis paths by default. When you need to view the analysis of 35 worst Setup paths, enter 35 in "Max Paths", as shown in Figure 4-29. The results can be found in the Setup and Hold reports.

The steps are as follows:

1. Select "Timing Constraints > Report Timing" and right-click to select "Create Report", as shown in Figure 4-28.

**Figure 4-28 Create Report Timing** 



- 2. Select "Create Report" and Figure 4-29 pops up.
  - Path: Specifies the max. paths, the max. common paths, the max./min. logic level, positive integers
  - Clocks: Specifies the associated clock of a path. From/To Clock indicates the transmitted clock and sample clock respectively; click
     " " on the right to select one.
  - Objects: Specifies the start and end objects of the analysis; click
     " " on the right to select one.
  - Analysis Type: Specifies Setup, Hold, Recovery and Removal.
  - Module Instance: Specifies the instance name; click " " on the right to select one.

SUG940-1.8.3E 30(77)



Figure 4-29 Report Timing Dialog Box

#### **Report High Fanout Nets**

It reports the number of fans for Net, 10 of the largest by default.

If you need to view the net between 5 and 7, you can specify Min Fanout as 5 and Max Fanout as 7. The results can be viewed in High Fanout Nets Report.

The steps are as follows:

- 1. Select "Timing Constraints > Report High Fanout Nets".
- 2. Right-click to select "Create Report", and Create Report dialog box pops up, as shown in Figure 4-30.

SUG940-1.8.3E 31(77)

Timing Constraints Max Net Number Max Fanout Number Min Fanout Number Report Clock Net Report Set/Reset Net Clocks Clock Latency Clock Uncertainty Create Report Clock Group I/O Delay ✓ Path False Path Max/Min Delay Multicycle Path ∨ Report Report Timing Report High Fanout Nets Report Route Congestion Report Min Pulse Width Report Max Frequency Set Operating Conditions Others Create Derive Clocks

Figure 4-30 Create Report High Fanout Nets

- 3. Select "Create Report" and Figure 4-31 pops up.
  - Max Net: Specifies the maximum, positive integer.
  - Min and Max Fanout: Specifies the min. and max. fanout, positive integer.
  - Report Clock Net: Reports the net connected to the clock input of the timing component.
  - Report Set/Reset Net: Reports the net connected to the reset input of the timing component.
  - Ascending: Specifies the net order, ascending by default.

Figure 4-31 Report High Fanout Nets Dialog Box

| ₩ Report Fanout Nets                      | ?         | ×     |
|-------------------------------------------|-----------|-------|
|                                           |           |       |
| Max Net: 10                               |           |       |
| Min Fanout:                               |           |       |
| Max Fanout:                               |           |       |
| ☐ Report Clock Net ☐ Report Set/Reset Net | Ascending |       |
|                                           | OK C      | ancel |

SUG940-1.8.3E 32(77)

#### **Report Route Congestion**

It reports the route congestion, 10 of the worst grid by default.

It usually reports the congestion on a specific grid, such as the Grid R4C4. The results can be seen in Route Congestions Report.

The steps are as follows:

- Select "Timing Constraints > Report Route Congestion".
- Right-click and select "Create Report", as shown in Figure 4-32.

**Figure 4-32 Report Route Congestion Interface** 



- 3. Select "Create Report" and Figure 4-33 pops up.
  - Max Grid Number: Specifies max. number of grid.
  - Min and Max Route Congestion: Specifies the min. and route congestion; Floating point accurate to three decimal places.
  - Grid Location: Specifies the grid, such as R4C4.

Figure 4-33 Report Route Congestion Dialog Box

|                       |    | ?  | ×     |
|-----------------------|----|----|-------|
|                       |    |    |       |
| Max Grid Number: 10   |    |    |       |
| Min Route Congestion: |    |    | (0-1) |
| Max Route Congestion: |    |    | (0-1) |
| Grid Location:        |    |    |       |
|                       | 0K | Cs | ncel  |

SUG940-1.8.3E 33(77)

#### Report Min Pulse Width

It reports the minimum pulse width, 10 by default. You can use this constraint to report a pulse width in a specific range or on a specific object. If a Reg11\_Z exists in the design, you can specify Reg11\_Z. The results can be viewed in Minimum Pulse Width Report.

The steps are as follows:

- Select "Timing Constraints > Report Min Pulse Width".
- 2. Right-click and select "Create Report", as shown in Figure 4-34.

Figure 4-34 Create Report Min Pulse Width



- 3. Select "Create Report" and Figure 4-35 pops up.
  - Max Clock Path: Specifies the maximum, positive integer.
  - Minimum and Maximum Pulse Width: Specifies the min. and max. pulse width; floating point accurate to three decimal places.
  - Detail: Whether a detailed path is reported.
  - Objects: Specifies the timing component that needs to be reported, only flip flop supported, such as DFF; click "—" to select one.

SUG940-1.8.3E 34(77)

Figure 4-35 Report Min Pulse Width Dialog Box



#### **Report Max Frequency**

It reports the max. operating frequency and Gowin Software reports the max. frequency of the top by default. Users can specify the max. operating clock frequency for a specific module whose max. operating clock frequency timing critical path is not limited to within this module itself but is related to it.

The steps are as follows:

- Select "Timing Constraints > Report > Report Max Frequency".
- 2. Right-click in the blank space on the right, and "Create Report" pops up, as shown in Figure 4-36.

Figure 4-36 Create Report Max Frequency



3. Select "Create Report" and Figure 4-37 pops up. Type the instance name in "Module Instance" and click "..." to select one.

SUG940-1.8.3E 35(77)

Figure 4-37 Report Max Frequency Dialog Box



#### Report Exception

It is used to report exceptions.

Report Exception is used to further constrain the timing paths acted upon by the exception constraint statement to report the timing paths that the user cares about.

The steps are as follows.

- 1. In main interface, select "Timing Constraints > Report > Report Exception".
- 2. Right-click on the right in the blank and "Create Report" pops up, as shown in Figure 4-38.

Figure 4-38 Create Report Exception



3. Select "Create Report" and Figure 4-39 pops up.

#### Note!

For the introduction of the options, see Report Timing.

SUG940-1.8.3E 36(77)

Report Exception × Clocks From clock: 🕶 To clock: • Objects • From: Through: To: • Analysis Type Setup O Hold Recovery O Removal Path Max Paths: Min Logic Level: Max Common Paths: Max Logic Level: ΟK Cancel

Figure 4-39 Report Exception Dialog Box

#### 4.7.6 Other Constraints

#### **Create Derive Clocks**

- A global target clock frequency can be created for the design.
- The frequency can be set, with a maximum of 1200MHz.
   You can add Derive Clocks constraints in two ways:
- 1. Through the Constraints menu
  - Select "Constraints > Create Derive Clocks..." to open the "Create Derive Clocks" dialog, as shown in Figure 4-40.

Figure 4-40 Create Derive Clocks



- b) Frequency (MHz): Global target frequency, a positive floating point less than or equal to 1200, accurate to three decimal places.
- 2. Click "Others > Create Derive Clocks" to create Derive Clocks.

SUG940-1.8.3E 37(77)

Right-click in the blank space, choose "Create Derive Clocks" to create Derive Clocks, as shown in Figure 4-41.

Figure 4-41 Select Create Derive Clocks



Once the clock is created, the Derive Clocks list will display the corresponding constraints, as shown in Figure 4-42.

Figure 4-42 Derive Clocks List



SUG940-1.8.3E 38(77)

#### 4.7.7 Save

After editing all constraints, click "File > Save" or "File > Save As" to save the constraints in .sdc file, see <u>Appendix A Timing Constraints Syntax</u> for details.

# 4.8 Priority of Timing Constraints

Gowin Software provides multiple types of timing constraints. The following priority is from low to high.

- create\_clock and create\_generated\_clock
- 2. set\_multicycle\_path
- set\_max\_delay and set\_min\_delay
- 4. set\_false\_path
- set\_clock\_groups

#### Note!

Only the timing constraints which may produce competition on the same path can be sorted.

SUG940-1.8.3E 39(77)

# 5 Timing Report

This chapter will describe Gowin STA to help you learn the timing report. As shown in Figure 5-1, the report includes the navigation bar and the content bar, and the title in the navigation bar will be highlighted in red when there is no analysis.

Figure 5-1 Static Timing Analysis Report



SUG940-1.8.3E 40(77)

5 Timing Report 5.1 Timing Summaries

# 5.1 Timing Summaries

Timing Summaries include four parts: STA Tool Run Summary, Clock Summary, Max Frequency Summary and Total Negative Slack Summary, as shown in Figure 5-2.

**Figure 5-2 Timing Summaries** 

# **Timing Summaries**

#### STA Tool Run Summary:

| Setup Delay Model                   | Slow 1.14V 85C C5/I4 |
|-------------------------------------|----------------------|
| Hold Delay Model                    | Fast 1.26V 0C C5/I4  |
| Numbers of Paths Analyzed           | 42                   |
| Numbers of Endpoints Analyzed       | 17                   |
| Numbers of Falling Endpoints        | 0                    |
| Numbers of Setup Violated Endpoints | 0                    |
| Numbers of Hold Violated Endpoints  | 0                    |

#### **Clock Summary:**

| NO. | Clock Name | Туре | Period | Frequency(MHz) | Rise  | Fall  | Source | Master | Objects |
|-----|------------|------|--------|----------------|-------|-------|--------|--------|---------|
| 1   | clk0       | Base | 10.000 | 100.000        | 0.000 | 5.000 |        |        | clk     |

#### Max Frequency Summary:

| NO. | Clock Name | Constraint   | Actual Fmax  | Logic Level | Entity |
|-----|------------|--------------|--------------|-------------|--------|
| 1   | clk0       | 100.000(MHz) | 147.195(MHz) | 4           | TOP    |

#### Total Negative Slack Summary:

| Clock Name | Analysis Type | Endpoints TNS | Number of Endpoints |
|------------|---------------|---------------|---------------------|
| clk0       | Setup         | 0.000         | 0                   |
| clk0       | Hold          | 0.000         | 0                   |

# 5.1.1 STA Tool Run Summary

- Setup Delay Model: Data model for setup analysis used by Gowin Software, and the default is Slow model.
- Hold Delay Model: Data model for hold analysis used by Gowin Software, and the default is Fast model.
- Numbers of Paths Analyzed: The number of static timing analysis paths. As shown in Figure 5-3, three timing paths, Path1, Path2 and Path3, are analyzed.
- Numbers of Endpoints Analyzed: The endpoint of the analysis timing path. As shown in Figure 5-3, three endpoints are analyzed, labeled as Endpoint1, Endpoint2 and Endpoint3.

SUG940-1.8.3E 41(77)

5 Timing Report 5.1 Timing Summaries

 Numbers of Falling Endpoints: The number of falling edges triggered of endpoints analysis. As shown in Figure 5-3, if the reg12 is DFFN and the trigger mode is the falling edge, D is the endpoint of falling edge.

- Numbers of Setup Violated Endpoints: The number of the endpoints that can not meet setup after timing analysis.
- Numbers of Hold Violated Endpoints: The number of the endpoints that can not meet hold after timing analysis.

Figure 5-3 Path & Endpoints



# 5.1.2 Clock Summary

It reports all clocks in the user design. If the clock in the design is not constrained, the software will automatically create a clock by default. The clock for Arora family is 100MHz, and the clock for LittleBee family is 50MHz; if GAO design included, TCK frequency is 20MHz.

- NO.: Number
- Clock Name: The name of the clock. By default, when Gowin Software creates a clock, if a clock name is duplicated, it will automatically add the suffix "\_gowin". For PLL, OSC, and CLKDIV types, Gowin Software will add the suffix ".default\_gen\_clk" to the clock name by default.
- Type: Base and Generated. Base represents the base clock and Generated represents the generated clock
- Period: Clock period
- Frequency (MHz): Clock frequency
- Rise: Clock rise time
- Fall: Clock fall time
- Source: Clock source from PORT, PIN, NET, REG
- Master: The generated clock is the master clock
- Objects: Clock objects such as PORT, PIN, NET, REG

SUG940-1.8.3E 42(77)

# 5.1.3 Max Frequency Summary

- NO.: Number
- Clock Name: Clock name that drives the timing model.
- Constraint: Clock frequency of SDC or the default clock frequency when there is no SDC constraint.
- Actual Fmax: The max. actual frequency after PnR.
- Logic Level: Logical level.
- Entity: The max. frequency of modules. The default is TOP.

#### Note!

- When there is no drive timing model after PnR, it is "No timing paths to get frequency
  of \*".
- The max. clock frequency only reports the clock on the timing model (including generated clock) driven by the same clock.
- It is recommended to add complete timing constraints to the design enable Gowin Software to analyze them more accurately.

## 5.1.4 Total Negative Slack Summary

- Clock Name: The name of the clock
- Analysis Type: Setup or Hold
- Endpoints TNS: The time of the endpoints with Total Negative Slack (TNS) in timing path driven by clocks (Corresponding ClockName); only the worst paths are counted for common endpoints.
- Number of Endpoints: The number of endpoints with Total Negative Slack (TNS) in the timing path driven by clocks (Corresponding ClockName); only the worst paths are counted for common endpoints.

#### Note!

Only the timing models driven by the same clock are reported.

# 5.2 Timing Details

#### 5.2.1 Path Slacks Table

The path slacks table includes Setup Paths Table, Hold Paths Table, Recovery Paths Table, and Removal Paths Table, and the details are shown in Figure 5-4.

- Path Number: Up to 25 by default.
- Path Slack: It is equal to the time of data request minus the time of data arrival, and the timing is not satisfied when it is negative.
- From Node: The start node for timing analysis of the previous level timing component.

SUG940-1.8.3E 43(77)

 To Node: The end node for timing analysis of the next level timing component.

- From Clock: The clock and edge of the previous level timing component, and the edge type refers to the rising or falling edge.
- To Clock: The latch clock and latch edge of the next level timing component.
- Relation: The time relationship between the transmitting clock and the sampling clock.
- Clock Skew: The time difference between the transmitting clock and the sampling clock to arrive at the previous level and next level timing components.
- Data Delay: Data delay on the path.

#### Note!

- It reports "Nothing to report!" when no timing path is available for analysis.
- The worst 25 paths are analyzed by default. If the path you need to check is not within these 25 paths, the SDC constraint command report\_timing can be used to report.
   For the details, see Report Timing.
- Timing path of clock domain crossing is analyzed by default. If you do not care about clock domain crossing analysis, you can configure through set\_clk\_group or set\_false\_path. For the details, see <u>Set Clock Uncertainty</u> or <u>Set False Path</u>.

#### Figure 5-4 Path Slacks Table

#### Path Slacks Table:

#### **Setup Paths Table**

Report Command:report\_timing -setup -max\_paths 25 -max\_common\_paths 1

| Path Number | Path Slack | From Node   | To Node     | From Clock | To Clock | Relation | Clock Skew | Data Delay |
|-------------|------------|-------------|-------------|------------|----------|----------|------------|------------|
| 1           | 8.806      | synS_r_s0/Q | synE_r_s0/D | ck0:[R]    | ck0:[R]  | 10.000   | 0.000      | 0.794      |

#### **Hold Paths Table**

Report Command:report\_timing -hold -max\_paths 25 -max\_common\_paths 1

| Path Number | Path Slack | From Node   | To Node     | From Clock | To Clock | Relation | Clock Skew | Data Delay |
|-------------|------------|-------------|-------------|------------|----------|----------|------------|------------|
| 1           | 0.570      | synS_r_s0/Q | synE_r_s0/D | ck0:[R]    | ck0:[R]  | 0.000    | 0.000      | 0.570      |

#### Recovery Paths Table

Report Command:report\_timing -recovery -max\_paths 25 -max\_common\_paths 1

| Path Number | Path Slack | From Node     | To Node           | From Clock | To Clock | Relation | Clock Skew | Data Delay |
|-------------|------------|---------------|-------------------|------------|----------|----------|------------|------------|
| 1           | 8.649      | rstSrc_r_s0/Q | rstObj_r_s0/CLEAR | ck0:[R]    | ck1:[R]  | 10.000   | 0.000      | 1.278      |

#### **Removal Paths Table**

Report Command:report\_timing -removal -max\_paths 25 -max\_common\_paths 1

| Path Number | Path Slack | From Node     | To Node           | From Clock | To Clock | Relation | Clock Skew | Data Delay |
|-------------|------------|---------------|-------------------|------------|----------|----------|------------|------------|
| 1           | 0.788      | rstSrc_r_s0/Q | rstObj_r_s0/CLEAR | ck0:[R]    | ck1:[R]  | 0.000    | 0.000      | 0.833      |

SUG940-1.8.3E 44(77)

#### 5.2.2 Minimum Pulse Width Table

It is the minimum pulse width table which can be recognized by timing component. Pulse width is the duration of active high/low level signals. The worst 10 paths are reported by default, as shown in Figure 5-5. The table header is described as follows:

- Number: Ascending order, 10 paths by default.
- Slack: The slack value of the minimum pulse width.
- Actual Width: The actual pulse width that the component can recognize in STA after PnR.
- Required Width: The minimum pulse width required by the component.
- Type: Low Pulse Width and High Pulse Width.
- Clock: Clock for minimum pulse width analysis.
- Objects: Instance object of timing component for minimum pulse width analysis.

#### Note!

It reports as "Nothing to report!" when there is no minimum pulse width analysis report.

Figure 5-5 Minimum Pulse Width Table

#### **Minimum Pulse Width Table:**

Report Command:report\_min\_pulse\_width -nworst 10 -detail

| Number | Slack | Actual Width | Required Width | Туре             | Clock       | Objects |
|--------|-------|--------------|----------------|------------------|-------------|---------|
| 1      | 2.738 | 4.238        | 1.500          | Low Pulse Width  | DEFAULT_CLK | reg12   |
| 2      | 2.738 | 4.238        | 1.500          | Low Pulse Width  | DEFAULT_CLK | reg11_Z |
| 3      | 2.813 | 4.313        | 1.500          | High Pulse Width | DEFAULT_CLK | reg12   |
| 4      | 2.813 | 4.313        | 1.500          | High Pulse Width | DEFAULT_CLK | reg11_Z |

# 5.2.3 Timing Report By Analysis Type

This section includes Setup Analysis Report, Hold Analysis Report, Recovery Analysis Report and Removal Analysis Report, where Setup Analysis Report includes Recovery Analysis Report and Hold Analysis Report includes Removal Analysis Report. The analysis methods are consistent. The four types of analysis are described below.

#### **Setup Analysis Report**

The setup analysis report is used to analyze the time to stablize data before the clock rising edge arrives. If the time is not enough, the data will not be stably transmitted to the timing component at the clock rising edge.

Gowin Software calculates, analyzes and prints the arrival time, request time, sampling clock and transmitting clock on the path for reference.

The report is generated by the command report\_timing -setup. Gowin

SUG940-1.8.3E 45(77)

Software analyzes and reports the 25 timing paths with the worst slack by default, including Path Summary, Data Arrival Path and Path Statistics.

- 1. Path Summary, as shown in Figure 5-6, is a summary of the path:
  - Slack: The latest time of arrival minus the actual time of arrival of the data. Positive value indicates timing closure, and negative value indicates timing non-closure.
  - Data Arrival Time: The time of launch edge to arrive at the data port of the next level timing component.
  - Data Required Time: The time of latch edge to arrive at the clock port of the next level timing component.
  - From: The previous level timing component.
  - To: The next level timing component.
  - Launch Clock: The clock that provides the launch edge and the edge type. The edge includes R (Rise) and F (Fall).
  - Latch Clock: The clock that provides the latch edge and the edge type. The edge includes R and F.

Figure 5-6 Path Summary

#### Path Summary:

| Slack              | 5.789       |
|--------------------|-------------|
| Data Arrival Time  | 6.767       |
| Data Required Time | 12.556      |
| From               | reg11_Z     |
| То                 | reg12_Z     |
| Launch Clk         | sysclk1:[R] |
| Latch Clk          | sysclk1:[R] |

- 2. Data Arrival Path, as shown in Figure 5-7, is the path of data arriva, and the header is described below:
  - At: A time node on the timing path.
  - DELAY: A delay value meaning a time interval.
  - TYPE: The type of node on the timing path, which is not available when null.

#### Note!

In Figure 5-7, TYPE descriptions are as follows:

- tCL: Time of clock latency; clock source latency.
- tINS: Time of module instance; instantiated component delay.
- tNET: Time of net; the delay of net.
- tC2Q: Time of clock to quit; the internal delay of timing component.
- RF: The signal transfer type of the component currently being analyzed.

SUG940-1.8.3E 46(77)

- FANOUT: Fanout.
- LOC: The physical position of the currently analyzed component in the device, and UNPLACE means no location, such as DHCEN.
- NODE: Node on the static timing analysis path, including instance name, port, clock, and active clock edge time.

Figure 5-7 Data Arrival Path

Data Arrival Path:

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysclk1                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL7[A]    | clk1_ibuf/I            |
| 0.943 | 0.943 | tINS | RR | 2      | IOL7[A]    | clk1_ibuf/O            |
| 3.236 | 2.293 | tNET | RR | 1      | IOL2[B]    | reg11_Z/CLK            |
| 3.786 | 0.550 | tC2Q | RF | 1      | IOL2[B]    | reg11_Z/Q              |
| 6.767 | 2.981 | tNET | FF | 1      | R5C9[1][A] | reg12_Z/D              |

3. Data Required Path: The data required path is the path through which the clock reaches the clock port from the active edge, as shown in Figure 5-8.

#### Note!

In Figure 5-8, the meaning of type is as followings.

tUnc: Time of clock uncertainty

tSu: Time of setup

Figure 5-8 Data Required Path

Data Required Path:

| AT     | DELAY  | ТҮРЕ | RF | FANOUT | LOC        | NODE                   |
|--------|--------|------|----|--------|------------|------------------------|
| 10.000 | 10.000 |      |    |        |            | active clock edge time |
| 10.000 | 0.000  |      |    |        |            | sysdk1                 |
| 10.000 | 0.000  | tCL  | RR | 1      | IOL7[A]    | clk1_ibuf/I            |
| 10.943 | 0.943  | tINS | RR | 2      | IOL7[A]    | clk1_ibuf/O            |
| 13.236 | 2.293  | tNET | RR | 1      | R5C9[1][A] | reg12_Z/CLK            |
| 13.036 | -0.200 | tUnc |    |        |            | reg12_Z                |
| 12.556 | -0.480 | tSu  |    | 1      | R5C9[1][A] | reg12_Z                |

- 4. Path Statistics is the statistics of the path, as shown in Figure 5-9.
  - Clock Skew: Clock skew.
  - Setup Relationship: The time relationship between the previous level timing component transmitting data and the next level timing component latching data.
  - Logic Level: Logic levels.
  - Arrival Clock Path Delay: The clock delay on the Data Arrival Path.
     Cell indicates the logical delay; Route indicates the route delay, and tC2Q indicates the internal delay.
  - Arrival Data Path Delay: The data delay on the Data Arrival Path.
  - Required Clock Path Delay: The clock delay on the Data Required

SUG940-1.8.3E 47(77)

#### Path.

#### Figure 5-9 Path Statistics

#### Path Statistics:

| Clock Skew                | 0.000                                                            |  |  |  |
|---------------------------|------------------------------------------------------------------|--|--|--|
| Setup Relationship        | 10.000                                                           |  |  |  |
| Logic Level               | 1                                                                |  |  |  |
| Arrival Clock Path Delay  | cell: 0.943, 29.131%; route: 2.293, 70.869%                      |  |  |  |
| Arrival Data Path Delay   | cell: 0.000, 0.000%; route: 2.981, 84.423%; tC2Q: 0.550, 15.577% |  |  |  |
| Required Clock Path Delay | cell: 0.943, 29.131%; route: 2.293, 70.869%                      |  |  |  |

#### **Hold Analysis Report**

Figure 5-10 is hold analysis report, which is used to analyze the time to stablize data after the the clock rising edge arrives. If the time is not enough, the data will not be stably transmitted to the timing component. Gowin Software calculates and analyzes the arrival time, request time, sampling clock and transmitting clock on the path. The report is generated by the command report\_timing - hold. It reports the 25 timing paths with the worst slack by default. For the report header, see Setup Analysis Report.

Figure 5-10 Hold Analysis Report



| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysyclk                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL11[A]   | clk_ibuf/I             |
| 0.811 | 0.811 | tINS | RR | 2      | IOL11[A]   | clk_ibuf/O             |
| 2.533 | 1.723 | tNET | RR | 1      | R2C9[0][A] | reg11_s0/CLK           |
| 2.933 | 0.400 | tC2Q | RR | 1      | R2C9[0][A] | reg11_s0/Q             |
| 3.554 | 0.621 | tNET | RR | 1      | R2C9[1][A] | reg12_s0/CLEAR         |

#### Data Required Path:

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysyclk                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL11[A]   | clk_ibuf/I             |
| 0.811 | 0.811 | tINS | RR | 2      | IOL11[A]   | clk_ibuf/O             |
| 2.533 | 1.723 | tNET | RR | 1      | R2C9[1][A] | reg12_s0/CLK           |
| 2.533 | 0.000 | tUnc |    |        |            | reg12_s0               |
| 2.551 | 0.018 | tHId |    | 1      | R2C9[1][A] | reg12_s0               |

#### Path Statistics:

| Clock Skew                | 0.000                                                            |
|---------------------------|------------------------------------------------------------------|
| Hold Relationship         | 0.000                                                            |
| Logic Level               | 1                                                                |
| Arrival Clock Path Delay  | cell: 0.811, 31.998%; route: 1.723, 68.002%                      |
| Arrival Data Path Delay   | cell: 0.000, 0.000%; route: 0.621, 60.818%; tC2Q: 0.400, 39.182% |
| Required Clock Path Delay | cell: 0.811, 31.998%; route: 1.723, 68.002%                      |

SUG940-1.8.3E 48(77)

#### **Recovery Analysis Report**

Figure 5-11 is the recovery time report, which analyzes the shortest stability time for asynchronous clear/set/reset signals before the timing component is on the active clock edge. If the time is not met, the flip flop may not operate. The report is generated by the command report\_timing -recovery. It reports the 25 timing paths with the worst slack by default. For the table header, see Setup Analysis Report.

Figure 5-11 Recovery Analysis Report



#### **Removal Analysis Report**

Figure 5-12 is removal time report, which analyzes the shortest stability time for asynchronous clear/set/reset signals after the timing component is on the positive edge. If the time is not met, the flip flop may not operate. The analysis and calculation is the same as the hold time. The report is generated by the command report\_timing - removal. It reports the 25 timing paths with the worst slack by default. For the table header, see Hold Analysis Report.

SUG940-1.8.3E 49(77)

Figure 5-12 Removal Analysis Report

sysydk:[R]

svsvdk:[R]

Launch Clk

Latch Clk

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysyclk                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL11[A]   | clk_ibuf/I             |
| 0.811 | 0.811 | tINS | RR | 2      | IOL11[A]   | clk_ibuf/O             |
| 2.533 | 1.723 | tNET | RR | 1      | R2C9[0][A] | reg11_s0/CLK           |
| 2.933 | 0.400 | tC2Q | RR | 1      | R2C9[0][A] | reg11_s0/Q             |
| 3.554 | 0.621 | tNET | RR | 1      | R2C9[1][A] | reg12_s0/CLEAR         |

#### Data Required Path:

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysyclk                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL11[A]   | clk_ibuf/I             |
| 0.811 | 0.811 | tINS | RR | 2      | IOL11[A]   | clk_ibuf/O             |
| 2.533 | 1.723 | tNET | RR | 1      | R2C9[1][A] | reg12_s0/CLK           |
| 2.533 | 0.000 | tUnc |    |        |            | reg12_s0               |
| 2.551 | 0.018 | tHld |    | 1      | R2C9[1][A] | reg12_s0               |

#### Path Statistics:

| Clock Skew                | 0.000                                                            |  |  |  |  |
|---------------------------|------------------------------------------------------------------|--|--|--|--|
| Hold Relationship         | 0.000                                                            |  |  |  |  |
| Logic Level               | 1                                                                |  |  |  |  |
| Arrival Clock Path Delay  | cell: 0.811, 31.998%; route: 1.723, 68.002%                      |  |  |  |  |
| Arrival Data Path Delay   | cell: 0.000, 0.000%; route: 0.621, 60.818%; tC2Q: 0.400, 39.182% |  |  |  |  |
| Required Clock Path Delay | cell: 0.811, 31.998%; route: 1.723, 68.002%                      |  |  |  |  |

# 5.2.4 Minimum Pulse Width Report

The minimum pulse width report analyzes all the minimum pulse width on the timing analysis path. As shown in Figure 5-13, the description is as follows.

- Actual Width: The actual pulse width, whose value is Early clock Path minus Late clock Path.
- Required Width: The minimum width required by the component, that is, the minimum time for pulse signal to hold. If it is less than that width, the level pulse will not be recognized.
- Slack: The actual pulse width minus the required pulse width.
- Type: The pulse type. Low Pulse Width and High Pulse Width.
- Clock: Clock for STA.
- Objects: The current objects.
- Late clock Path: For the high pulse width, it is the path from which the logic high signal starts. For the low pulse width, it is the path from which the logic low signal starts.
- Late Clock Path: The path where the clock arrives the latest.

SUG940-1.8.3E 50(77)

Early Clock Path: The path where the clock arrives the earliest.

Figure 5-13 Minimum Pulse Width



# 5.2.5 High Fanout Nets Report

High fanout nets report analyzes all the net fanout on the timing analysis path, and also the worst slack and max. delay. The default value is 10. As shown in Figure 5-14, the description is as follows:

- FANOUT: The fanout.
- NET NAME: The net name.
- WORST SLACK: The worst slack on the net and more than one slack may on one net.
- MAX DELAY: The max. delay on the net.

Figure 5-14 High Fanout Nets Report



# **5.2.6 Route Congestions Report**

**High Fanout Nets Report:** 

As shown in Figure 5-15, the description is as follows:

- GRID LOC: The location of grid.
- ROUTE CONGESTIONS: The route congestion on the grid, such as 0.056, indicating that the route congestion is 5.6%.
- It reports 10 of the worst by default, in descending order.

SUG940-1.8.3E 51(77)

Figure 5-15 Route Congestions Report

#### **Route Congestions Report:**

Report Command:report\_route\_congestion -max\_grids 10

| GRID LOC | ROUTE CONGESTIONS |
|----------|-------------------|
| R5C9     | 0.056             |
| R2C1     | 0.028             |
| R3C1     | 0.028             |
| R3C9     | 0.028             |
| R1C1     | 0.014             |
| R5C1     | 0.014             |

# **5.2.7 Timing Exceptions Report**

In the following, the Timing Exceptions Report is illustrated by a case. For the case in Figure 5-16, design a specific SDC file, as shown in Figure 5-17.

#### Figure 5-16 Test Case

```
1 module timing(
  output dout,
  input din, clk1, clk2
  );
5
6
  reg reg11, reg12;
  reg reg21, reg22;
9
  always @(posedge clk1)
2 Degin
3
      reg11 <= din;
      reg12 <= reg11;
5
   end
6
  always @(posedge clk2)
8 Degin
9
      reg21 <= din;
0
      reg22 <= ~reg21;
1
2
3
  assign dout = reg22 & reg12;
5 endmodule
```

#### **Figure 5-17 Timing Exceptions Constraints**

```
create_clock -name sysclk1 -period 10 -waveform {0 5} [get_ports {clk1}]
create_clock -name sysclk2 -period 10 -waveform {0 5} [get_ports {clk2}]
set_max_delay -from [get_clocks {sysclk1}] -to [get_clocks {sysclk1}] 5
set_max_delay -from [get_clocks {sysclk2}] -to [get_clocks {sysclk2}] 4
```

The set\_max\_delay in Figure 5-17 is to set sysclk1 and sysclk2 to 5ns and 4ns respectively. The set\_max\_delay affects the setup analysis and the affected path is displayed by default in the timing exceptions report, and the generated report is shown in Figure 5-18.

SUG940-1.8.3E 52(77)

**Figure 5-18 Timing Exceptions Report** 

# Timing Exceptions Report: Setup Analysis Report

Report Command:report\_exceptions -setup -max\_paths 5 -max\_common\_paths 1

 $Timing\ Path\ Constraint[1]: set\_max\_delay\ -from\ [get\_clocks\ \{sysclk1\}]\ -to\ [get\_clocks\ \{sysclk1\}]\ 5$ 

Path1

#### Path Summary:

| Slack              | 0.789       |
|--------------------|-------------|
| Data Arrival Time  | 6.767       |
| Data Required Time | 7.556       |
| From               | reg11_Z     |
| То                 | reg12_Z     |
| Launch Clk         | sysclk1:[R] |
| Latch Clk          | syscik1:[R] |

#### Data Arrival Path:

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysclk1                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL7[A]    | clk1_ibuf/I            |
| 0.943 | 0.943 | tINS | RR | 2      | IOL7[A]    | clk1_ibuf/O            |
| 3.236 | 2.293 | tNET | RR | 1      | IOL2[B]    | reg11_Z/CLK            |
| 3.786 | 0.550 | tC2Q | RF | 1      | IOL2[B]    | reg11_Z/Q              |
| 6.767 | 2.981 | tNET | FF | 1      | R5C9[1][A] | reg12_Z/D              |

#### Data Required Path:

| AT    | DELAY  | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|--------|------|----|--------|------------|------------------------|
| 5.000 | 5.000  |      |    |        |            | active clock edge time |
| 5.000 | 0.000  |      |    |        |            | sysclk1                |
| 5.000 | 0.000  | tCL  | RR | 1      | IOL7[A]    | clk1_ibuf/I            |
| 5.943 | 0.943  | tINS | RR | 2      | IOL7[A]    | clk1_ibuf/O            |
| 8.236 | 2.293  | tNET | RR | 1      | R5C9[1][A] | reg12_Z/CLK            |
| 8.036 | -0.200 | tUnc |    |        |            | reg12_Z                |
| 7.556 | -0.480 | tSu  |    | 1      | R5C9[1][A] | reg12_Z                |

#### Path Statistics:

| Clock Skew                | 0.000                                                            |  |  |  |
|---------------------------|------------------------------------------------------------------|--|--|--|
| Setup Relationship        | .000                                                             |  |  |  |
| Logic Level               | 1                                                                |  |  |  |
| Arrival Clock Path Delay  | ell: 0.943, 29.131%; route: 2.293, 70.869%                       |  |  |  |
| Arrival Data Path Delay   | cell: 0.000, 0.000%; route: 2.981, 84.423%; tC2Q: 0.550, 15.577% |  |  |  |
| Required Clock Path Delay | rell: 0.943, 29.131%; route: 2.293, 70.869%                      |  |  |  |

Timing Path Constraint[14]: set\_max\_delay -from [get\_clocks {sysclk2}] -to [get\_clocks {sysclk2}] 4

Path 1

#### Path Summary:

| Slack              | 1.616       |
|--------------------|-------------|
| Data Arrival Time  | 4.940       |
| Data Required Time | 6.556       |
| From               | reg21_Z     |
| То                 | reg22_Z     |
| Launch Clk         | sysclk2:[R] |
| Latch Clk          | syscik2:[R] |

#### Data Arrival Path:

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 0.000 | 0.000 |      |    |        |            | active clock edge time |
| 0.000 | 0.000 |      |    |        |            | sysclk2                |
| 0.000 | 0.000 | tCL  | RR | 1      | IOL5[A]    | clk2_ibuf/I            |
| 0.943 | 0.943 | tINS | RR | 2      | IOL5[A]    | clk2_ibuf/O            |
| 3.236 | 2.293 | tNET | RR | 1      | R5C9[0][B] | reg21_Z/CLK            |
| 3.786 | 0.550 | tC2Q | RR | 1      | R5C9[0][B] | reg21_Z/Q              |
| 4.189 | 0.403 | tNET | RR | 1      | R5C9[0][A] | reg21_i_cZ/I0          |
| 4.940 | 0.751 | tINS | RF | 1      | R5C9[0][A] | reg21_i_cZ/F           |
| 4.940 | 0.000 | tNET | FF | 1      | R5C9[0][A] | reg22_Z/D              |

#### Data Required Path:

| AT    | DELAY | TYPE | RF | FANOUT | LOC        | NODE                   |
|-------|-------|------|----|--------|------------|------------------------|
| 4.000 | 4.000 |      |    |        |            | active clock edge time |
| 4.000 | 0.000 |      |    |        |            | sysclk2                |
| 4.000 | 0.000 | tCL  | RR | 1      | IOL5[A]    | clk2_ibuf/I            |
| 4.943 | 0.943 | tINS | RR | 2      | IOL5[A]    | clk2_ibuf/O            |
| 7 236 | 2 203 | INFT | RR | 1      | R5C9[0][A] | ren22 7/CLK            |

The timing exceptions report defaults to report all exceptions paths,

SUG940-1.8.3E 53(77)

> and Gowin Software provides the report\_exception constraints command, which allows you to configure and display some of the contents that are concerned and filter the paths that are not concerned.

> Add the report\_exception statement on the basis of Figure 5-17, as shown in Figure 5-19, the first line in the red box indicates that the path affected by sysclk1 reports a setup analysis, and the second line indicates that the path affected by sysclk2 does not report a setup analysis.

Figure 5-19 report\_exception Statement

```
create_clock -name sysclk1 -period 10 -waveform {0 5} [get_ports {clk1}] create_clock -name sysclk2 -period 10 -waveform {0 5} [get_ports {clk2}] set_max_delay -from [get_clocks {sysclk1}] -to [get_clocks (sysclk1)] set_max_delay -from [get_clocks [sysclk2]] -to [get_clocks [sysclk2]] 4
report_exceptions -setup -from_clock [get_clocks {sysclk1}] -to_clock [get_clocks {sysclk1}] -max_paths 1 -max_common_paths 1 report_exceptions -setup -from_clock [get_clocks {sysclk2}] -to_clock [get_clocks {sysclk2}] -max_paths 0 -max_common_paths 0
```

After constraints as shown in Figure 5-19, the timing exceptions report is as shown in Figure 5-20.

#### Figure 5-20 report\_exception Report

5.000

cell: 0.982, 33.942%; route: 1.911, 66.058%

cell: 0.982, 33.942%; route: 1.911, 66.058%

cell: 0.000, 0.000%; route: 4.596, 90.932%; tC2Q: 0.458, 9.068%

Path Statistics:

Logic Level

#### Timing Exceptions Report: Setup Analysis Report[1]: Report Command:report\_exceptions -setup -from\_clock [get\_clocks {sysclk1}] -to\_clock [get\_clocks {sysclk1}] -max\_paths 1 -max\_paths 1 -max\_common\_paths 1 Timing Path Constraint[1]: set\_max\_delay -from [get\_clocks {sysclk1}] -to [get\_clocks {sysclk1}] 5 Path Summary: 7.947 Data Required Time reg11\_ins23 reg12\_ins20 Data Arrival Path: 0.000 0.000 active clock edge time sysclk1 0.000 0.000 0.000 0.000 tCL RR IOL15[A] clk1\_ibuf13/I 0.982 0.982 tINS RR IOL15[A] dk1\_ibuf13/0 2.893 1.911 tNET RR IOL2[B] reg11\_ins23/CLK 3.351 0.458 tC2Q RF IOL2[B] reg11\_ins23/Q 7.947 4.596 FF R15C23[1][A] reg12\_ins20/D tNET Data Required Path: 5.000 5.000 active clock edge time 5.000 0.000 sysclk1 5.000 0.000 tCL IOL15[A] clk1 ibuf13/I 5.982 0.982 tINS RR IOL15[A] dk1 ibuf13/0 7.893 1.911 tNET RR R15C23[1][A] reg12\_ins20/CLK 7.693 -0.200 tUnc reg12\_ins20 7.293 -0.400 tSu R15C23[1][A] reg12\_ins20

SUG940-1.8.3E 54(77)

# **5.2.8 Timing Constraints Report**

As shown in Figure 5-21, the description is as follows:

- SDC Command Type: Type of static timing constraint command.
- State: Includes Invalid and Actived. Actived indicates that the command takes effect, and Invalid indicates that the command is invalid.
- Detail Command: The value is equal to the corresponding timing constraints statement in the SDC file.

**Figure 5-21 Timing Constraints Report** 

#### **Timing Constraints Report:**

| SDC Command Type     | State   | Detail Command                                                                                                                                       |  |  |  |  |
|----------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| TC_CLOCK             | Actived | create_clock -name main -period 18.182 -waveform {0 9.091} [get_ports {dk}]                                                                          |  |  |  |  |
| TC_GENERATED_CLOCK   | Actived | create_generated_clock -name main_gen -source [get_ports {clk}] -master_clock main -divide_by 5 -duty_cycle 40 -phase 22 -offset 50 [get_ports {in}] |  |  |  |  |
| TC_INPUT_DELAY       | Actived | set_input_delay -clock main_gen 0.2 -clock_fall -add_delay -source_latency_included [get_ports {in}]                                                 |  |  |  |  |
| TC_CLOCK_LATENCY     | Actived | et_dock_latency -source 1.2 [get_docks {main}]                                                                                                       |  |  |  |  |
| TC_CLOCK_UNCERTAINTY | Actived | set_clock_uncertainty 2.3 -setup -from [get_clocks {main}] -to [get_clocks {main}]                                                                   |  |  |  |  |
| TC_FALSE_PATH        | Actived | set_false_path -from [get_clocks {main_gen}] -to [get_clocks {main_gen}]                                                                             |  |  |  |  |
| TC_MULTICYCLE        | Actived | set_multicycle_path -from [get_clocks {main_gen}] -to [get_clocks {main_gen}] -setup -end 3                                                          |  |  |  |  |
| TC_MAX_DELAY         | Actived | set_max_delay -from [get_clocks {main}] -to [get_clocks {main}] 1.11                                                                                 |  |  |  |  |
| TC_CLOCK_GROUP       | Actived | set_dock_groups -exclusive -group [get_docks {main}] -group [get_docks {main_gen}]                                                                   |  |  |  |  |
|                      | Actived | eport_timing -setup -from_clock [get_clocks {main}] -to_clock [get_clocks {main}]                                                                    |  |  |  |  |
|                      | Actived | eport_exceptions -setup -from_clock [get_clocks {main}] -to_clock [get_clocks {main}]                                                                |  |  |  |  |

SUG940-1.8.3E 55(77)

# Appendix A Timing Constraints Syntax Specification

Gowin timing constraints syntax specification references the standard SDC (Synopsys Design Constraint), which provides efficient timing constraints on designs to meet specific timing requirements.

It supports the wildcard character "?" and "\*"; "?" matches a single character, and "\*" matches zero or more characters and supports cross-hierarchy matching. It also supports timing constraints in multiple lines.

# A.1 Clock Constraints

# A.1.1 create\_clock

#### Syntax

Command: create\_clock

Parameter: -period <period\_value>

[-name <clock\_name>]

[-waveform <edge\_list>]

<objects>

[-add]

-period: Specify the period of clock. The parameter value should be greater than 0, and the period unit is ns.

-name: Specify the clock name. The clock name must be unique. If the new created clock has the same name with already created clock, the already created clock will be overwritten with new created clock. If the

SUG940-1.8.3E 56(77)

name is not specified, the name of first source objects will be regarded as clock name.

-waveform: Specify the time of the rising edge and falling edge of clock. The difference time between rising edge and falling edge should be less than one period. In general, if the rising edge arrives first, both the rising edge time and the falling edge time should be less than one period. For example, "{0 5}" means the clock rising edge arrives at 0ns, and the clock falling edge arrives at 5ns; if the clock falling edge arrives, set the clock rising edge time to less than one period, and the falling edge time to equal to or greater than one period. If the period is set to 10ns, "-waveform {5 10}" means the clock falling edge arrives at 0ns, and the clock falling edge arrives at 5ns.

-add: Use -add option to add multiple clocks to the same source object, or the new created clock with different clock name on the same source object will be ignored when the source object already has one created clock.

<objects> Specify the object of the clock, such as get\_ports, get\_pins, get\_nets, and get\_regs,etc. When the source object already has one created clock, you can create new clock with -add command. If source object is not specified when you create clock with create\_clock command, Gowin Software will ignore this command.

#### **Examples**

Example 1: Use the wildcard? to match a single character, such as clk or cck.

create\_clock -name ck -period 100 -waveform {0 50} [get\_ports {c?k}]

Example 2: Use the wildcard \* to match zero or more characters, such as clk or clock.

create\_clock -name ck -period 100 -waveform {0 50} [get\_ports {c\*k}]

Example 3: Create a clock ck with a period of 10 ns and on the port clk.

create\_clock -name ck -period 10.000 -waveform {5 10} [get\_ports {clk}]

Example 4: For a DCS with four clock inputs, use the -add option to create four clocks (clk0, clk1, clk2, clk3) on the DCS output port.

create\_clock -name clk0 -period 10 -waveform {0 5} [get\_pins
{dcs\_inst/CLKOUT}]

create\_clock -name clk1 -period 10 -waveform {0 4} [get\_pins {dcs\_inst/CLKOUT}] -add

create\_clock -name clk2 -period 10 -waveform {0 3} [get\_pins {dcs\_inst/CLKOUT}] -add

SUG940-1.8.3E 57(77)

create\_clock -name clk3 -period 10 -waveform {0 2} [get\_pins
{dcs\_inst/CLKOUT}] -add

# A.1.2 create\_generated\_clock

#### **Syntax**

-name: Specify the name of the generated clock. If –name is not specified, the name of first source object will be regarded as clock name, the clock name must be unique. If the new created clock has the same name with the already created clock, the already created clock will be overwritten with new created clock.

-source: Specify the source where generated clock is from; if there are more than one clocks, master\_clock option must be used to specify the master clock; and it supports get\_ports, get\_pins, get\_nets and get\_regs.

-master\_clock: Specify the master clock of the generated clock.

-edges: Specify the edge list of generated clock; this option specifies a three positive ascending order integer parameter list, which indicates the relationship between the first rising edge of generated clock, the first falling edge of generated clock, the second rising edge of generated clock and the master clock edge. For instance, we mark the first rising edge of master

SUG940-1.8.3E 58(77)

clock as 1, the next falling edge is 2, the next rising edge is 3 ..., the marker numbers of master clock edges are elements of edge list; we can create a 2 divider generated clock with "-edges {1 3 5}".

-edge\_shift: Specify the edge shift of each edge, should be used together with "-edges" option. It can be specified as any number, but the edge can not go beyond the adjacent border.

#### Note!

"-edge" and "-edge\_shift" can not be used together with the other parameters used for waveform adjustment, except "-invert".

- -divide\_by: Specify the divider value.
- -multiply\_by: Specify the multiplier value.
- -duty\_cycle: Specify the duty cycle of generated clock.
- -add: When specify this option, this clock can coexist with existing clock.
  - -invert: Specify if invert the waveform of the generated clock.
  - -phase: Specify the phase shift of clock edges.
  - -offset: Specify the offset of clock edges.
- <objects>: Specify the input port of clock; it supports the set of
  get\_ports, get\_pins, get\_nets and get\_regs.

#### **Examples**

Example 1: Create a divide-by-2 derived clock based on clk on port a. create\_clock -period 10 [get\_ports {clk}]

create\_generated\_clock -name genClk -source [get\_ports {clk}]
-divide\_by 2 [get\_ports {a}]

Example 2: Create a multiply-by 2 derived clock with a 40% duty cycle.

create\_clock -period 10 [get\_ports {clk}]

create\_generated\_clock -name genClk0 -source [get\_ports {clk}]
-multiply\_by 2 -duty\_cycle 40 [get\_pins {pll\_out}]

Example 3: Create a multiply-by 2 derived clock with a 90-degree phase shift.

create\_clock -period 10 [get\_ports {clk}]

create\_generated\_clock -name genClk2 -source [get\_ports {clk}]
-multiply\_by 2 -phase 90 [get\_pins {pll\_out}]

Example 4: Create a pair of derived clocks based on the same source but with different master clocks.

SUG940-1.8.3E 59(77)

```
create_clock -period 10 -name clk [get_ports {clk}]
create_clock -period 20 -name clk1 -add [get_ports {clk}]
create_generated_clock -name genClk -source [get_ports {clk}]
-divide_by 2 -master_clock clk -add [get_pins {pll_out}]
create_generated_clock -name genClk1 -source [get_ports {clk}]
-master_clock clk1 -divide_by
```

# A.1.3 set\_clock\_latency

#### **Syntax**

```
Command: set_clock_latency
Parameter: -source [-rise | -fall]

[-late | -early]

<delay>

[-clock <clock list>]

<object list>
```

-source: Indicate the clock source delay, mandatory.

-rise | -fall: Specify the rising | falling clock latency. -rise| -fall can not be specified at one statement. If both are not specified, the clock latency is applied to all conditions.

-late | -early: Specify the max. or min. latency; For setup analysis, late acts on the launch clock and early acts on the latch clock, while for hold analysis, it is the opposite of setup.

<delay>: Specify the clock source latency value, and the default is 0.

#### Note!

The value of late should be greater than or equal to the value of early, otherwise late will be calculated according to the value of early.

-clock: You can specify the clock which source latency affected on when more than one clocks are on one source object, if this parameter is not configured, all clock have same delay; and it supports the set of get\_clocks.

<source objects>: Specify the delay source objects; and it supports
get\_clocks, get\_ports, get\_pins, get\_nets and get\_regs.

#### **Examples**

Example 1: Specify a 2ns clock latency for clock clk.

SUG940-1.8.3E 60(77)

```
create_clock -period 10 -name clk [get_ports {clk}]
set_clock_latency -source 2 [get_clocks {clk}]
```

Example 2: Set the clock source latency for the rising edge of clock cck on port clk, and specify the late and early values as 0.111 and 0.011, respectively.

```
create_clock -period 10 -name cck [get_ports {clk}]
```

set\_clock\_latency -source -rise -late 0.111 [get\_ports {clk}] -clock
[get\_clocks {cck}]

set\_clock\_latency -source -rise -early 0.011 [get\_ports {clk}] -clock
[get\_clocks {cck}]

Example 3: Set the clock source latency for the falling edge of clock cck on port clk, and specify the late and early values as 0.222 and 0.022, respectively.

```
create_clock -period 10 -name cck [get_ports {clk}]
set_clock_latency -source -fall -late 0.222 [get_ports {clk}] -clock
[get_clocks {cck}]
```

set\_clock\_latency -source -fall -early 0.022 [get\_ports {clk}] -clock
[get\_clocks {cck}]

## A.1.4 set\_clock\_uncertainty

#### **Syntax**

```
Command: set_clock_uncertainty

Parameter: [-from <from clock>]

[-rise_from <rise from clock>]

[-fall_from <-fall from clock>]

[-to <to clock>]

[-rise_to <rise to clock>]

[-fall_to <fall to clock>]

[-setup | -hold]

<uncertainty value>
```

-from/-rise\_from/-fall\_from: Specify the start clock of uncertainty; "-rise\_from" and "-fall\_from" specify the valid start clock edge of uncertainty, supporting the set of get\_clocks.

-to/-rise\_to/-fall\_to: Specify the end clock of uncertainty; "-rise\_to" and "-fall to" specify the valid clock edge of the end of uncertainty, supporting

SUG940-1.8.3E 61(77)

the set of get\_clocks.

-setup/-hold: Specify whether the uncertainty has an effect on the setup time or hold time; it is exclusive for the same constraint statement; if neither is specified, both checks are valid.

<uncertainty value>: Uncertainty value

#### Note!

At least one launch clock or latch clock must be specified, otherwise the constraints are invalid.

#### **Examples**

Example 1: Set the setup uncertainty for the clock from clk to clk to 0.5.

create\_clock -period 10 -name clk [get\_ports {clk}]

set\_clock\_uncertainty -setup -from [get\_clocks {clk}] -to [get\_clocks
{clk}] 0.5

Example 2: Set the hold uncertainty for the clock from clk to clk to 0.1.

create\_clock -period 10 -name clk [get\_ports {clk}]

set\_clock\_uncertainty -hold -from clk -to clk 0.1

Example 3: Set clk as the launch clock, and specify the setup uncertainty as 0.111 and the hold uncertainty as 0.222.

create\_clock -period 10 -name clk [get\_ports {clk}]

set\_clock\_uncertainty 0.111 -setup -from [get\_clocks {clk}]

set\_clock\_uncertainty 0.222 -hold -from [get\_clocks {clk}]

Example 4: Set clk as the latch clock, and specify the setup uncertainty as 0.111 and the hold uncertainty as 0.222.

create\_clock -period 10 -name clk [get\_ports {clk}]

set\_clock\_uncertainty 0.111 -setup -to [get\_clocks {clk}]

set\_clock\_uncertainty 0.222 -hold -to [get\_clocks {clk}]

# A.1.5 set\_clock\_groups

#### **Syntax**

Command: set\_clock\_groups

Parameter: [-asynchronous | -Exclusive]

[-group <clock name>].

-asynchronous | -Exclusive: Specify the clocks, asynchronous or exclusive.

-group: Specify the clocks as the same group, supporting the collection of one or more clocks using the set of get\_clocks

SUG940-1.8.3E 62(77)

## **Examples**

Example 1: Set the relationship between clock clk0 and clock clk1 as mutually exclusive.

```
create_clock -period 10 -name clk0 [get_ports {clk0}]
    create_clock -period 10 -name clk1 [get_ports {clk1}]
    set_clock_groups -exclusive -group [get_clocks {clk0}] -group
[get_clocks {clk1}]
```

# A.2 I/O Delay Constraints

# A.2.1 set\_input\_delay

## **Syntax**

```
Command: set_input_delay

Parameter: -clock clock_name

[-clock_fall]

[-rise]

[-fall]

[-max]

[-min]

[-add_delay]

[-source_latency_included]

<delay_value>

<port_list>
```

-clock: Specifies which clock the input port is associated with.

-clock\_fall: Indicates that the input port is associated with the falling edge of the clock. If this parameter is not specified, the default association is with the rising edge of the clock.

-rise / -fall: Specifies the input delay of the data for the rising or falling edge. If only one is specified, the other is automatically assigned the same value.

-max / -min: Specifies the maximum or minimum input delay for data, affecting setup and hold times. If only one is specified, the other is automatically assigned the same value.

-add\_delay: Allows multiple constraints of this type to take effect simultaneously. The tool automatically matches corresponding values for setup and hold analysis.

SUG940-1.8.3E 63(77)

-source\_latency\_included: Specifies the external clock delay is already included in the input delay. If not specified, the external clock delay is not included in the input delay.

<delay\_value>: Specifies the input delay value, defaulting to 0ns.

<port\_list>: Specifies the input ports (PORT) affected by the constraint,
supporting the get\_ports set.

### **Examples**

Example 1: Set the input delay of input port a based on clk to 0.8ns and analyze the path from the input port to the timing component.

```
create_clock -period 10 -name clk [get_ports {clk}]
set_input_delay -clock clk 0.8 [get_ports {a}]
Example 2: Set four types of delays for port a based on clk.
create_clock -period 10 -name clk [get_ports {clk}]
set_input_delay -clock clk -max -rise 1.4 [get_ports {a}]
set_input_delay -clock clk -max -fall 1.5 [get_ports {a}]
set_input_delay -clock clk -min -rise 0.7 [get_ports {a}]
set_input_delay -clock clk -min -fall 0.8 [get_ports {a}]
Example 3: Use wildcard '*' to match 'd0', 'd1', etc.
set_input_delay -clock cck0 -max 1.4 [get_ports {d*}]
```

# A.2.2 set\_output\_delay

### **Syntax**

```
Command: set_output_delay

Parameter: -clock clock_name

[-clock_fall]

[-rise]

[-fall]

[-max]

[-min]

[-add_delay]

[-source_latency_included]

<delay_value>

<port list>
```

-clock: The "-clock" parameter specifies the clock associated with the output delay.

SUG940-1.8.3E 64(77)

-clock\_fall: Specifies that the output delay is related to the falling edge of clock. If not specified, the rising edge is associated by default.

-rise/-fall: Specifies the output delay for the rising or falling edge of the data. If only one is specified, the other is automatically assigned the same value.

-max/-min: Specifies the maximum or minimum output delay, which affects setup and hold. If only one is specified, the other is automatically assigned the same value.

-add\_delay: Allows multiple constraints of this type to take effect simultaneously, with the tool automatically matching corresponding values for setup and hold analysis.

-source\_latency\_included: Specifies the external clock latency is included in the output delay.

<delay\_value>: Specifies the output delay value, with a default of 0.

<port\_list>: Specifies the constrained output ports (PORT), supporting
the get\_ports set.

### Examples

Example 1: Set the output delay of out based on the clk to 0.5ns and analyze the path from the timing component to the output port.

```
create_clock -period 10 -name clk [get_ports {clk}]
set_output_delay -clock clk 0.5 [get_ports {out}]
```

Example 2: Set the four types of output delays for the out based on the clk.

```
create_clock -period 10 -name clk [get_ports {clk}]
set_output_delay -clock clk -max -rise 0.3 [get_ports {out}]
set_output_delay -clock clk -max -fall 0.5 [get_ports {out}]
set_output_delay -clock clk -min -rise 0.8 [get_ports {out}]
set_output_delay -clock clk -min -fall 0.7 [get_ports {out}]
```

Example 3: Analyze the timing path from the input port data\_in to the output port data\_out.

```
create_clock -period 10 -name clk [get_ports {clk}]
set_input_delay -clock clk 0.8 [get_ports {data_in}]
set_output_delay -clock clk 0.5 [get_ports {data_out}]
```

SUG940-1.8.3E 65(77)

# **A.3 Timing Path Constraints**

# A.3.1 set\_max\_delay/ set\_min\_delay

### **Syntax**

Command: set\_max\_delay

Parameter: [-from <from list>]

[-to <to list>]

[-through <through\_list>]

<delay value>

Command: set\_min\_delay

Parameter: [-from <from list>]

[-to <to list>]

[-through <through\_list>]

get\_clocks, get\_ports, get\_regs, get\_pins.

<delay value>
-from: Used to specify the start of the path; and it supports the sets of

-to: Used to specify the end of the path; and it supports the sets of get\_clocks, get\_ports, get\_regs, get\_pins.

-through: Specify the pins or nets through the path; it supports the sets of get\_pins, get\_nets, and the pins can only be the ones of non-timing component. Only one "-through can be used in one statement at one time.

<delay value>: Specify output delay value.

#### Note!

- The set\_max\_delay constraint affects the setup clocks and set\_min\_delay affects the hold clocks.
- The three parameters above can be used together or alone. If the basic objects of the three parameters are not on the same path, Gowin Software will ignore this constraints, and timing analysis will not be affected.

### **Examples**

Example 1: Set the maximum delay for the timing path from the component driven by clk0 to the component driven by clk1 to 5ns.

create\_clock -period 10 -name clk0 [get\_ports {clk0}] create\_clock -period 10 -name clk1 [get\_ports {clk1}]

SUG940-1.8.3E 66(77)

set\_max\_delay -from [get\_clocks {clk0}] -to [get\_clocks {clk1}] 5

Example 2: Use wildcards \* and ?, and the clock relationship between ports d00, d10 and registers r0, r1 is 2ns.

```
set_max_delay -from [get_ports {d*}] -to [get_regs {r?}] 2
```

Example 3: Analyze the maximum delay from the input port in to the output port out as 2ns.

```
set_max_delay -from [get_ports {in}] -to [get_ports {out}] 2
```

Example 4: Set the maximum delay from register reg0 to the timing component driven by the falling edge of clk as 2ns.

```
create_clock -period 10 -name clk [get_ports {clk}]
```

set\_max\_delay -from [get\_regs {reg0}] -to [get\_clocks {clk}] 2

Example 5: Set the minimum delay for the timing path from the component driven by clk to the component driven by clk to 0.5ns.

```
create_clock -period 10 -name clk [get_ports {clk}]
```

set\_min\_delay -from [get\_clocks {clk}] -to [get\_clocks {clk}] 0.5

Example 6: Set the minimum delay from the input port in to the output port out as 0.5ns.

set\_min\_delay -from [get\_ports {in}] -to [get\_ports {out}] 0.5

# A.3.2 set\_false\_path

### **Syntax**

```
Command: set_false_path
```

Parameter: [-from <from list>]

[-to <to list>]

[-through <through list>]

[-setup]

[-hold]

-setup/-hold: Specify constraints for setup time or hold time. The two parameters are mutually exclusive. If not specified, it is valid for both setup and hold by default.

-from: Specify the start of the path; it can be collected through the sets of get\_ports, get\_regs, ger\_pins or get\_clocks, which can be used separately, and Gowin software automatically gets the end.

-to: Specify the end of the path; it can be collected through the sets of get\_ports, get\_regs, ger\_pins, get\_clocks, which can be used separately,

SUG940-1.8.3E 67(77)

and Gowin software automatically gets the start.

-through: Specify the pins or nets through the path, and it supports the sets of get\_pins, get\_nets. In the parameter list, you can specify multiple pins (PIN) or multiple nets (NET), which can be on the same path or on different paths; multiple "-through" parameters cannot be used in the same constraint.

#### Note!

If the set of get\_pins is used, the value of -from must be a clock pin; the value of -to must be a non-clock pin; the value of -through must be an output pin such as DFF.Q or a rx pin such as DFF.D or DFF.CE on the path.

### **Examples**

Example 1: Set a false path from clock clk0 to clock clk1.

create\_clock -period 10 -name clk0 [get\_ports {clk0}]

create\_clock -period 10 -name clk1 [get\_ports {clk1}]

set\_false\_path -from [get\_clocks {clk0}] -to [get\_clocks {clk1}]

Example 2: Set a path from register reg0 to register reg1 without timing analysis.

set\_false\_path -from [get\_regs {reg0}] -to [get\_regs {reg1}]

Example 3: Specify the path from input port in to output without timing analysis.

set\_false\_path -from [get\_ports {in}] to [get\_ports {out}]

Example 4: Use -from alone, valid for both setup and hold.

set\_false\_path -from [get\_regs {reg0\_s0}]

Example 5: Use -to alone, valid for setup.

set\_false\_path -to [get\_regs {reg0\_s0}] -setup

Example 6: Use -to alone, valid for hold.

set\_false\_path -from [get\_regs {reg0\_s0}] -hold

Example 7: Use -through alone, paths through reg0\_s0.Q will not be analyzed.

set\_false\_path -through [get\_pins {reg0\_s0/Q}]

Example 8: Use -through alone, paths through reg0\_c will not be analyzed.

set\_false\_path -through [get\_nets {reg0\_c}]

Example 9: Use wildcard \* to match multiple characters, such as mi/reg0.

set\_false\_path -from [get\_regs {mi/r\*0}] -to [get\_regs {spi/Reg0}]

Example 10: Use wildcard? to match a single character, such as reg0, reg1.

SUG940-1.8.3E 68(77)

set\_false\_path -from [get\_pins {mi/r?g0/CLK}] -to [get\_pins {spi/DI}]

## A.3.3 set\_multicycle\_path

## **Syntax**

Command: set\_multicycle\_path

Parameter: [-setup|-hold]

[-start|-end]

[-from <from\_list>]

[-to <to list>]

[-through <through\_list>]

<path multiplier>

-start/-end: Specify whether the constraint reference clock is a launch clock or a latch clock; the reference clock specified by the parameter "-start" is a launch clock; the reference clock specified by the parameter "-end" is a latch clock. The default is a latch clock.

-setup/-hold: Specify whether the current constraint affects setup check or hold check; these two parameters are mutually exclusive. The default is to affect the setup check.

-from: The start of the path, and it can collect the start by sets of get\_pins, get\_ports, get\_regs, get\_clocks.

-to: The end of the path, and it can collect the end by sets of get\_pins, get\_ports, get\_regs, get\_clocks.

-through: Specify the pins or nets through the path, and it supports the sets of get\_pins, get\_nets. In the parameter list, you can specify multiple pins (PIN) or multiple nets (NET), which can be on the same path or on different paths; multiple "-through" parameters cannot be used in the same constraint.

<path multiplier>: Specify the number of the cycles.

#### Note!

"-from", "-to", and "-through" can be used together or alone. If the specified objects of the three parameters are not on the same path, Gowin Software will ignore this constraints, and timing analysis will not be affected.

### **Examples**

Example 1: Set a multicycle path for setup time with a value of 2 clock cycles.

SUG940-1.8.3E 69(77)

```
create_clock -name clk -period 10 [get_ports {clk}]
create_generated_clock -name genClk -multiply_by 2 -source
[get_ports {clk}] [get_pins {pll_out}]
set_multicycle_path -end -setup -from [get_clocks {clk}] -to [get_clocks {genClk}] 2
Example 2: Use wildcard ? and *; ? matches addr0, addra, and *
matches Data_s0, D0_s0.
set_multicycle_path -from [get_regs {SD/addr? }] -to [get_regs {RSG/D*_s0}]
```

# A.4 Operating Conditions Constraints

### **Syntax**

- -grade: Specify the device temperature grade, supporting commercial, industrial and automotive grade.
- -model: Specify the timing analysis model.
- speed: Specify the device speed grade.
- -setup: Setup time check under current process corner; and it has the same function as -max.
- -hold: Hold time check under current process corner; and it has the same function as -min.
- -max: Setup time check under current process corner; and it has the same function as –setup.
- -min: Hold time check under current process corner; and it has the same function as -hold.
- -max\_min: Setup time and hold time check under current process corner; it has the same function as -setup and -hold.

SUG940-1.8.3E 70(77)

### **Examples**

Example 1: # Industry speed level 6 and fast model have an effect on setup and hold analysis.

set\_operating\_conditions -grade i -model fast -speed 6 -setup -hold

Example 2: # Industry speed level 7 and slow model have an effect on setup and hold analysis.

set\_operating\_conditions -grade c -model slow -speed 7 -max\_min

# **A.5 Timing Report Constraints**

# A.5.1 report\_timing

## **Syntax**

```
Command: report_timing
Parameter:[-setup|-hold|-recovery|-removal]
       [-max_paths <value>]
       [-max_common_paths < value >]
       [-rise_from <rise_from_list>]
       [-fall_from <fall_from_list>]
       [-to <to list>]
       [-rise_to <rise_to_list>]
       [-fall_to <fall_to_list>]
       [-through <through list>]
       [-from_clock<from clok>]
       [-fall_from_clock <from clok>]
       [-rise_from_clock <from clok>]
       [-to_clock <to clok>]
       [-rise_to_clock <to clok>]
       [-fall_to_clock <to clok>]
       [-min_logic_level]
       [-max_logic_level]
       [-mod_ins {mod_ins1 mod_ins2 ...}]
```

-setup|-hold|-recovery|-removal: Specify the type of timing check, exclusive.

-max\_paths: Specify the maximum number of paths of timing report, and the default is 25. If the number of specified paths does not reach the

SUG940-1.8.3E 71(77)

setting value, the worst path of the unspecified paths will be added to meet the requirement.

-max\_common\_paths: Specify the maximum number of paths sharing the common end of timing report.

-from/-rise\_from/-fall\_from: Specify the start of the timing report paths; -rise/fall\_from needs to be clocks and supports the set of get\_clocks; when used alone, Gowin Software automatically gets the start.

-to /-rise\_to /-fall\_to: Specify the end of the timing report path; -rise/fall\_to needs to be a clock and supports the set of get\_clocks; when used alone, Gowin Software automatically gets the end.

-through: Specify the pins or nets through the path, and it suppotst the set get\_nets, get\_pins.

-from\_clock /-fall\_from\_clock /-rise\_from\_clock: Specify the clock associated with the start of the timing report path and it supports the set of get\_clocks; when used alone, Gowin Software automatically gets the end.

-to\_ clock /-rise\_to\_ clock /-fall\_to\_clock: Specify the clock associated with the end of the timing report path and it supports the set of get\_clocks; when used alone, Gowin Software automatically gets the start.

-min\_logic\_level/-max\_logic\_level: Limit the logic level of the reporting paths.

-mod\_ins {mod\_ins1 mod\_ins2 ...}: Specify multiple instantiated module instances, separated by spaces; if this parameter is not added, the timings in the whole design are reported by default.

#### **Examples**

Example 1: Specify a report for setup time, with a maximum of 100 paths and a maximum of 5 common paths.

report\_timing -setup -max\_paths 100 -max\_common\_paths 5

Example 2: Report the path from the timing component reg0 to reg1.

report\_timing -from [get\_regs {reg0}] -to [get\_regs {reg1}]

Example 3: Specify the logic level as 2, report at most 2 paths, and report at most 1 common path.

create\_clock -name clk -period 10 [get\_ports {clk}]

report\_timing -from\_clock [get\_clocks {clk}] -to\_clock [get\_clocks {clk}] -max\_paths 2 -max\_common\_paths 1 -max\_logic\_level 2 -min\_logic\_level 2

Example 4: Report the timing within the module uut.

SUG940-1.8.3E 72(77)

report\_timing -mod\_ins {uut}

# A.5.2 report\_high\_fanout\_nets

## **Syntax**

```
Command: report_high_fanout_nets

Parameter: [-clock_regions]

[-slr]

[-ascending]

[-max_nets <max_net_value>]

[-min_fanout <min_fanout_value>]

[-max_fanout <max_fanout_value>]
```

-clock\_regions: Optional; when specified, report the clock net connecting to the clock input of timing component only.

-slr: Optional; when specified, report the clock net connecting to the reset/set port (synchronous or asynchronous) of timing component only.

-ascending: Optional; the report nets fanout is arranged in descending order; if this parameter is not specified, the report nets fanout is arranged in ascending order by default.

-max\_net: Optional; this parameter specifies the maximum number of nets to report. When this parameter is not specified, the default maximum number of nets reported is 10.

-min\_fanout: Optional; this parameter specifies only the reported net fanout whose number is not less than this parameter value.

-max\_fanout: Optional; this parameter specifies only the reported net fanout whose number is not greater than this parameter value.

## **Examples**

Example 1: Report the NETs connecting the reset/set inputs of timing components, with the fanout in the range [1, 15], and report at most 10 paths.

report\_high\_fanout\_nets -slr -max\_nets 10 -min\_fanout 1 -max\_fanout 15

Example 2: Report at most 10 high fanout nets. report\_high\_fanout\_nets -max\_nets 10

SUG940-1.8.3E 73(77)

# A.5.3 report\_route\_congestion

## **Syntax**

Command: report\_route\_congestion

Parameter: [-max\_grids <max grids value>]

[-min\_route\_congestion <min route congestion value>]

[-max\_route\_congestion < max route congestion>]

[-LOC <position>]

-max\_grids: Optional; specify the maximum number of grids to report; if it is not specified, it reports the congestion of ten grids by default.

-min\_route\_congestion: Optional; specify the minimum route congestion of grid to report; if it is not specified, the default value is 0.

-max\_route\_congestion: Optional; specify the maximum route congestion of grid to report; if it is not specified, the default value is 1. Its value should not be less than parameter value min\_route\_congestion; or the warning is reported, this statement is ignored.

-LOC: Optional; specify the physical location of grids to report. It can be be a single location, such as R1C3, which means the grid of first row and the third column; it also can be a location range, such as R1C[1:3], which means the grid of column 1~3, row 3; R[1:3]C1, which means the grid of column 1~3; or R[1:3]C[1:3], which means the grid of column 1~3, row 1~3.

### **Examples**

Example: # Report the route congestion of grids locating on row 1 to 5, column 1 to 5 whose route congestion is between 0 and 0.5; and only the five with the highest congestion are reported.

report\_route\_congestion -max\_grids 5 -min\_route\_congestion 0 -max\_route\_congestion 0.5 -LOC R[1:5]C[1:5]

# A.5.4 report\_min\_pulse\_width

### **Syntax**

Command: report\_min\_pulse\_width

Parameter: [-nworst <nworst value>]

[-min\_pulse\_width <min pulse width value>]

[-max\_pulse\_width <max pulse width value>]

SUG940-1.8.3E 74(77)

[-detail]

[get\_regs {reglns name}]

- -nworst: Specify the number of the worst paths to report.
- -min\_pulse\_width: Specify the minimum pulse width of timing component to report.
- -max\_pulse\_width: Specify the maximum pulse width of timing component to report.
- -detail: The report will be detailed if this parameter is specified, otherwise the report will be brief.
- get\_regs {regIns name}: Specify reg, one or more regs can be specified.
   All flip flops pulse width timing analysis will be reported by default.

### **Examples**

Example 1: #Report the worst 3 clock paths that have pulse width between 0.1 and 4 in detail.

```
report_min_pulse_width -nworst 3 -min_pulse_width 0.1 -max_pulse_width 4 -detail
```

Example 2: #Report the worst 20 clock paths that have pulse width between 0.001 and 4 in brief.

report\_min\_pulse\_width -nworst 20 -min\_pulse\_width 0.001 -max\_pulse\_width 4

# A.5.5 report\_max\_frequency

### **Syntax**

Command: report\_max\_frequency

Parameter: -mod\_ins {mod\_ins1 mod\_ins2 ...}

-mod\_ins {mod\_ins1 mod\_ins2 ...}: specify multiple module instances, separated by a space; The whole design maximum frequency will be reported by default no matter this parameter is specified or not.

### **Examples**

Example: # Report the max. frequency of module bsram0. report\_max\_frequency -mod\_ins {bsram0}

# A.5.6 report\_exceptions

### Syntax

Command: report\_exceptions

Parameter: -setup|-hold | -recovery | removal

SUG940-1.8.3E 75(77)

```
[-max_paths<number>]
[-max_common_paths< number >]
[-max_logic_level <number>]
[-min_logic_level <number>]
[-rise_from <rise_from_list>]
[-fall_from <fall_from_list>]
[-to <to list>]
[-rise_to <rise_to_list>]
[-fall_to <fall_to_list>]
[-through <through list>]
[-rise_through < rise_through_list>]
[-fall_through <fall_through_list>]
[-from_clock<from clock>]
[-fall_from_clock<from clock>]
[-rise_from_clock<from clock>]
[-to_clock<to clock>]
[-rise_to_clock<to clock>]
[-fall_to_clock<to clock>]
```

The name, meaning, and use of its keywords are the same as those of report\_timing; and it reports the path generated by the exception constraint.

### Example

Example: Report one recovery timing path in the exception constraints. create\_clock -name clk -period 10 -waveform {0 5} [get\_ports {clk}] set\_max\_delay -from [get\_clocks {clk}] -to [get\_clocks {clk}] 0.22 report\_exceptions -recovery -from\_clock [get\_clocks {clk}] -to\_clock [get\_clocks {clk}] -max\_paths

SUG940-1.8.3E 76(77)

# **A.6 Other Constraints**

# A.6.1 derive\_clocks

## **Syntax**

Command: derive\_clocks

Parameters: -freq <value>

-freq: Global target frequency, a positive floating point less than or equal to 1200, accurate to three decimal places, unit in MHz.

## Example

Example: #Create a clock with a frequency of 100MHz for the global derive\_clocks -freq 100

SUG940-1.8.3E 77(77)

